创建 function 对象的两种方法:

方式一(推荐)

  function func1(){
alert(123);
return 8
} var ret = func1()
alert(ret)

方式二:var func2 = new Function("参数1", "参数n","函数体");

    var add = new Function("a", "b", "alert(a+b)")
add(1,2);
alert(add.length)

arguments 对象

获得参数的个数

  var ret=0;
function add(){
alert(arguments.length)
}
add(1,2,3,4,5)

获得参数的个数和值的总额

    var ret = 0;
function add(){
console.log(arguments.length);
console.log(arguments); for (var i in arguments){
ret += arguments[i]
}
return ret;
} alert(add(1,2,3,4))

控制抛出异常

    function func2(){
if (arguments.length != 3){
throw new Error("param should be 3")
}
} func2(1,2,3,4)

自执行函数

    (function(arg){console.log(arg);})('123')

instanceof

用于判断一个变量是否某个对象的实例

    var s = "hello";
var i = 8; alert(typeof(s));
alert(typeof(i)); var s2 = new String("hello2");
alert(typeof(s2))
alert(s2 instanceof String); var n = new Number(2);
alert(typeof(n))
alert(n instanceof Number);

在JavaScript中除了null和undefined以外其他的数据类型都被定义成了对象,也可以用创建对象的方法定义变量,String、Math、Array、Date、RegExp都是JavaScript中重要的内置对象,在JavaScript程序大多数功能都是通过对象实现的

JavaScript 有 11 种内置对象, 包括:

Array ,String , Date, Math, Boolean, Number Function, Global, Error, RegExp , Object

String对象

创建字符串对象:

    var s = "hello";
var s2 = new String("hello2"); alert(s);
alert(s2); // String 对象 length 方法
alert(s.length); // 遍历字符串
for (var i in s){
console.log(s[i])
}

各种方法

// 用于把字符串显示为斜体
document.write(s.italics()); // 用于把字符串显示为粗体
document.write(s.bold()); // 用于创建 HTML 锚
document.write(s.anchor("klvchen")); // 用于把字符串转化成大写
console.log(s.toUpperCase()); // 用于把字符串转化成小写
console.log(s.toLowerCase()); // charAt返回index位置的字符
console.log(s.charAt(3)); // charCodeAt返回index位置的Unicode编码
console.log(s.charCodeAt(3)); // search返回匹配字符串的首字符位置索引
console.log(s.search("l")); // match返回匹配字符串的数组,如果没有匹配则返回null
console.log(s.match("l")); console.log(s.match("l")[0]); // 取数组里面的值
console.log(s.match("l")[1]); // 替换子字符串
console.log(s.replace("e","E")); // 分割字符串
console.log(s.split("e")); // 连接字符串
console.log(s.concat(" world")); // 截取子字符串,右不包括
console.log(s.substr(1, 1));
console.log(s.substring(1, 4));
console.log(s.slice(1, -1)); // 返回指定第一个元素的位置
console.log(s.indexOf("l"));

Array对象

创建数组对象

// 方法一:
var arr = [1,2,3,4]; // 方法二:
var arr2 = new Array(1,2,3,4);
//var arr2 = new Array(5, "hello", true, [1,2]); // 输出数组对象的长度
console.log(arr.length);
console.log(arr2.length); // 定义一个长度为3的数组,数组的值因未定义则默认为空
var arr4 = new Array(3);
console.log(arr4[0]);
console.log(arr4[1]);
console.log(arr4[2]); // 数组是可变成的
var arr5 = new Array(3);
arr5[5] = 10;
console.log(arr5.length); // 二维数组
var arr6 = new Array(6, "klvchen", true, [1,2]);
alert(arr6[3][0]); // 连接数组-join方法
ret = ["hello", "world"].join(" &&& ");
alert(ret); // push pop这两个方法模拟的是一个栈操作, push 压栈, pop弹栈
var arr7 = [1, 4, 6];
arr7.push(13);
console.log(arr7);
var ret = arr7.pop();
alert(ret); // unshift shift。unshift是将value值插入到数组x的开始, shift是将数组x的第一个元素删除
var arr7 = [1, 4, 6];
arr7.unshift(45);
console.log(arr7);
arr7.shift();
console.log(arr7); // 数组排序。reverse 作用为颠倒数组元素;sort 作用为排序数组元素
var arr8 = [11, 5, 3, 7, 100];
arr8.reverse();
console.log(arr8);
console.log(arr8.sort()); // 按照从小到大排序
var arr8 = [11, 5, 3, 7, 100]; function mysort(a,b){
if (a>b){
return 1;
}else if(a<b){
return -1;
}else{
return 0;
}
} function mysort2(a,b){
return a-b;
} console.log(arr8.sort(mysort));
console.log(arr8.sort(mysort2));

作用域,作用域链

  • 作用域链在函数被解释的过程中已经创建(函数做为作用域)
  • 提前声明

JavaScript 基础(二) - 创建 function 对象的方法, String对象, Array对象的更多相关文章

  1. 2、JavaScript 基础二 (从零学习JavaScript)

     11.强制转换 强制转换主要指使用Number.String和Boolean三个构造函数,手动将各种类型的值,转换成数字.字符串或者布尔值. 1>Number强制转换 参数为原始类型值的转换规 ...

  2. 内置对象(Date String Math Array)

    什么是对象 JavaScript 中的所有事物都是对象,如:字符串.数值.数组.函数等,每个对象带有属性和方法. 对象的属性:反映该对象某些特定的性质的,如:字符串的长度.图像的长宽等: 对象的方法: ...

  3. JavaScript原生对象属性和方法详解——Array对象

    http://www.feeldesignstudio.com/2013/09/native-javascript-object-properties-and-methods-array/ lengt ...

  4. javascript(基础)_对数组的遍历方法总结(find, findIndex, forEach,)

    一.前言                                                                                                ...

  5. JavaScript基础二

    1.7 常用内置对象 所谓内置对象就是ECMAScript提供出来的一些对象,我们知道对象都是有相应的属性和方法 1.7.1 数组Array 1.数组的创建方式 字面量方式创建(推荐大家使用这种方式, ...

  6. JavaScript 基础(二)数组

    字符串, JavaScript 字符串就是用'' 和""括起来的字符表示. 字符字面量, \n 换行, \t 制表, \b 退格, \r 回车, \f 进纸, \\ 斜杠,\' 单 ...

  7. Gradle学习系列之二——创建Task的多种方法

    在本系列的上篇文章中,我们讲到了Gradle入门,在本篇文章中我们将讲到创建Task的多种方法. 请通过以下方式下载本系列文章的Github示例代码: git clone https://github ...

  8. JavaScript---网络编程(3)-Object、String、Array对象和prototype属性

    本节学习JavaScript的对象和方法(函数)~ Object 对象 提供所有 JScript 对象通用的功能. obj = new Object([value]) 参数 obj 必选项.要赋值为 ...

  9. JavaScript基础回顾知识点记录6-操作元素样式和事件对象(介绍基本使用)

    js 中 操作元素样式 通过js修改元素内联样式(设置和读取的都是内联样式) 获取当前元素显示的样式 <html> <head> <meta charset=" ...

随机推荐

  1. Javascript高级编程学习笔记(70)—— 事件(14)内存和性能

    由于事件处理程序是现代的web程序交互能力的提供者 所以在日常实践中,我们免不了要向页面中添加大量的事件处理程序(不管是用于用户交互还是用于统计用户数据) 在创建GUI(图形用户界面)的语言(如C#) ...

  2. Javascript高级编程学习笔记(61)—— 事件(5)UI事件

    UI事件 UI事件是指那些不一定与用户操作有关的事件 这些事件在DOM规范出现之前,都是以各种不同的形式存在于不同的浏览器 而在DOM事件中为了保证向后兼容,现有的UI事件如下: DOMActivat ...

  3. C++ Opencv Mat类型使用的几个注意事项及自写函数实现Laplace图像锐化

    为了提升自己对Opencv中Mat数据类型的熟悉和掌握程度,自己尝试着写了一下Laplace图像锐化函数,一路坎坷,踩坑不断.现将代码分享如下: #include <opencv2/opencv ...

  4. Web前端JQuery入门实战案例

    前端jquery入门到实战 为什么要学习Jquery?因为生活. 案例: <!DOCTYPE html> <html lang="zh-CN"> <h ...

  5. 工欲善其事,必先利其器-Python编辑器选择(2)

    前言:工欲善其事.必先利其器 一款顺手的好的编辑器可以让程序员写代码更得心应手,效率也会更高,但是编辑器本身没有好坏,只有使用者使用起来是否顺手而已,这里简单给大家介绍几款常用的可以编辑Python的 ...

  6. mac Navicat 破解+汉化(亲测可用)

    Navicat Premium 12 的版本 破解太麻烦,最后选择 Navicat Premium 11.0.16 下载:地址 提取码:h3rq ps:用的是功能,不是版本 为了一次就成功,请先执行下 ...

  7. 13 Tensorflow机制(翻译)

    代码: tensorflow/examples/tutorials/mnist/ 本文的目的是来展示如何使用Tensorflow训练和评估手写数字识别问题.本文的观众是那些对使用Tensorflow进 ...

  8. MaskRCNN-Keypoints

    这个月先写一篇吧,后面要复习数学考试了,可能到时候就忘了.今天写一个比较有意思的东西,关于人体的分割与姿态估计.如下图所示: 图片选自mask rcnn的论文,这里由于时间的关系,就不多叙述技术细节了 ...

  9. Perl构建和打包自己的模块

    当写好一个或多个模块后,可以将它构建.打包成"tar.gz",以便让别人安装或者上传到CPAN(如果愿意的话).对于模块的使用者来说,也不用再使用use lib 'LIB_PATH ...

  10. 翻译:load data infile(已提交到MariaDB官方手册)

    本文为mariadb官方手册:LOAD DATA INFILE的译文. 原文:https://mariadb.com/kb/en/load-data-infile/ 我提交到MariaDB官方手册的译 ...