开发者社区> 黑泽明军> 正文
阿里云
为了无法计算的价值
打开APP
阿里云APP内打开

day03_js学习笔记_02_js的内建对象、js的函数

简介: day03_js学习笔记_02_js的内建对象、js的函数 ============================================================================= =========================================...
+关注继续查看

day03_js学习笔记_02_js的内建对象、js的函数

=============================================================================
=============================================================================
涉及到的知识点有:
    三、js的内建对象
        (1) Number对象
        (2) Boolean对象
        (3) String对象
        (4) Array对象
        (4) Array对象
        (5) Date对象
        (6) Math对象
        (7 )RegExp对象
    四、js的函数(相当于java中的方法)
        1、js函数定义的方式
            (1) 普通方式
            (2) 匿名函数方式(开发中常用该方式)
            (3) 对象函数方式(开发中该方式基本不用)
        2、js函数的参数
        3、js函数的返回值
        4、js的全局函数(js内置定义好的函数(方法),可以直接调用)
            (1) 编码和解码函数
            (2) 强制类型转换函数(即通过构造方法传参转换)
            (3) 转成数字的函数(方法)
            (4) eval()函数(方法)        
=============================================================================
=============================================================================
day03_js学习笔记_02_js的内建对象、js的函数
-----------------------------------------------------------------------------
一、js的简介
二、js的基本语法
-----------------------------------------------------------------------------
三、js的内建对象
    (1) Number对象
        创建方式:
            var myNum = new Number(value);  // 传入参数,强转成数字类型的数据
            var myNum = Number(value);  // 简写方式
                布尔类型转数字类型     true转成1    false转成0
                字符串类型转数字类型   不能强转
        属性和方法:
            toString() 把数字转成字符串
            valueOf() 返回一个 Number 对象的基本数字值
        示例:
            var num = new Number(5); // 装箱
            alert(typeof num); // object 
            alert(typeof num.toString()); // string 
            alert(typeof num.valueOf());  // number 拆箱
--------------------------------------
    (2) Boolean对象
        创建方式:
            var bool = new Boolean(value); // 传入参数,强转成布尔类型的数据     
            var bool = Boolean(value); // 简写方式
                数字类型强转成布尔类型时     非零就是true            零就是false
                字符串类型强转成布尔类型时    非空字符串就是true       空字符串("")就是false
        属性和方法:
            toString() 把布尔转成字符串(即把逻辑值转换为字符串,并返回结果)
            valueOf() 返回一个 Boolean 对象的基本值(是boolean类型的)
        示例:
            var bool = new Boolean(5); // 装箱
            alert(typeof bool); // object 
            alert(typeof bool.toString()); // string 
            alert(typeof bool.valueOf());  // boolean 拆箱
--------------------------------------            
    (3) String对象
        创建方式:
            var str = new String(s);
            var str = String(s);
                注意:var str = "helllo"; 
                // 在js中此时的str不是对象,是一个伪对象,可以理解为包装类对象,也可以调用方法,但是在js中其本质不是对象哦!
                // 而在java中,此时的str是一个对象。
        属性和方法:
            length 字符串的长度属性
            
            charAt() 返回索引的字符
            charCodeAt() 返回索引字符的unicode
            indexOf() 返回字符的索引
            lastIndexOf() 逆向返回字符的索引
            split() 将字符串按照特殊字符切割成数组
            substr() 从起始索引号提取字符串中指定数目的字符(注意:第二个s不是大写,不是驼峰式的写法哦)
            substring() 提取字符串中两个指定的索引号之间的字符(包头不包尾)
            toUpperCase() 转大写
        示例:
            // var str = new String("a-b-cdc-FG");
            var str = "a-b-cdc-FG"; // 伪对象
            alert(str.length); // 10
            alert(str.charAt(4)); // c
            alert(str.charCodeAt(4)); // 99
            alert(str.indexOf("c")); // 4
            alert(str.lastIndexOf("c")); // 6
            var arr = str.split("-");
            for (var i = 0; i < arr.length; i++) {
                alert(arr[i]);
            }
            alert(str.substr(2, 3)); // b-c
            alert(str.substring(2, 3)); // b (包头不包尾)
            alert(str.toUpperCase()); // A-B-CDC-FG
            
            
            
            W3School离线手册(2014.3.24)
--------------------------------------
    (4) Array对象
        创建方式:
            var arr = new Array(); // 创建一个空数组
            var arr = new Array(size); // 创建一个指定长度的数据(超出长度还能加元素)
            var arr = new Array(element0, element1, ..., elementn); // 创建数组并直接实例化元素
            var arr = []; // 创建一个空数组
            var arr = [1, 2, 5, "java"]; // 创建数组并直接实例化元素
        属性和方法:
            length 数组的长度属性
            
            join() 把数组的所有元素放入一个字符串。元素通过指定的分隔符进行分隔
            pop() 删除并返回数组的最后一个元素
            push() 向数组的末尾添加一个或更多元素,并返回新的长度
            reverse() 反转数组
            sort() 对数组的元素进行排序(按照字符串字典顺序进行排序)
     示例:
var arr = [ 3, 7, 1, "java", 'js', true, 4 ]; alert(arr.length); // 7 alert(arr.join("-")); // 3-7-1-java-js-true-4 alert(arr.pop()); // 4 alert(arr); // 3,7,1,"java",'js',true alert(arr.push("R")); // 8 alert(arr); // 3,7,1,"java",'js',true,R alert(arr.reverse()); // 4,true,js,java,1,7,3 数组反转 alert(arr.sort()); // 1,3,4,7,java,js,true 按照字符串字典顺序进行排序 -------------------------------------- (5) Date对象 创建方式: var myDate = new Date(); var myDate = new Date(毫秒值); // 代表从1970-1-1到现在的一个毫秒值 属性和方法: getFullYear() 年 getMonth() 月 0-11 getDate() 日 1-31 getDay() 星期 0-6(星期日是0) getTime() 返回1970年1月1日午夜到指定日期(字符串)的毫秒数 toLocalString() 根据本地时间格式,把 Date 对象转换为字符串 示例: var date = new Date(); alert(date.toString()); // Mon Apr 23 2018 09:38:13 GMT+0800 (中国标准时间) alert(date.toLocaleString()); // 2018/4/23 上午9:38:13 alert("year:" + date.getFullYear()); // 2018 alert("month:" + date.getMonth()); // 3 alert("date:" + date.getDate()); // 23 alert("day:" + date.getDay()); // 1 var time1 = date.getTime(); var time2 = 3 * 24 * 60 * 60 * 1000; alert(new Date(time1 + time2).toLocaleString()); // 2018/4/26 上午9:38:13 -------------------------------------- (6) Math对象 创建方式: Math 对象并不像 Date 和 String 那样是对象的类,因此没有构造函数 Math(),像 Math.sin() 这样的函数只是函数,不是某个对象的方法。 您无需创建它,通过把 Math 作为对象使用就可以调用其所有属性和方法。(相当于java中的静态成员变量和静态成员方法) 属性和方法: PI 圆周率 abs() 绝对值 ceil() 对数进行向上舍入 floor() 对数进行向下舍入 pow(x, y) 返回 x 的 y 次幂 random() 0-1之间的随机数[0.1) round() 四舍五入 示例: var x = "-897"; alert(Math.abs(x)); // 897 var x = 12.34; var y = 2; var z = 4; alert(Math.ceil(x)); // 13 alert(Math.floor(x)); // 12 alert(Math.round(x)); // 12 alert(Math.pow(y, z)); // 16 alert(Math.random()); // 0-1之间的随机数[0.1) -------------------------------------- (7 )RegExp对象 创建方式: var reg = new RegExp(pattern); var reg = /^正则规则$/; 规则的写法: 方括号用于查找某个范围内的字符: [0-9] 查找任何从 0 至 9 的数字 [A-Z] 查找任何从大写 A 到大写 Z 的字符 [a-z] 查找任何从小写 a 到小写 z 的字符 [A-z] 查找任何从大写 A 到小写 z 的字符 [abc] 查找方括号之间的任何字符 [^abc] 查找任何不在方括号之间的字符 元字符(Metacharacter)是拥有特殊含义的字符: . 查找单个字符,除了换行和行结束符 \d 查找数字 \D 查找非数字字符 \w 查找单词字符 \W 查找非单词字符 \s 查找空白字符 \S 查找非空白字符 b\ 匹配单词边界 B\ 匹配非单词边界 量词: n+ 出现至少一次 n* 出现0次或多次 n? 出现0次或1次 {5} 出现5次 {2,8} 出现2到8次 方法: test(str) 检索字符串中指定的值。返回 truefalse 示例: 校验邮箱: var reg = /^[A-z]+[A-z0-9_-]*\@[A-z0-9]+\.[A-z]+$/; var email = "haohao_827@163.com"; alert(reg.test(email)); ----------------------------------------------------------------------------- 四、js的函数(相当于java中的方法) 1、js函数定义的方式 (1) 普通方式 语法: function 函数名(参数列表) { 函数体; } 示例: function method() { alert("xxx"); } method(); (2) 匿名函数方式(开发中常用该方式) 语法: function(参数列表) { 函数体; }; 示例: var method = function() { alert("yyy"); }; method; // 不执行函数体 method(); // 执行函数体 用处: 后面学BOM时会学一个定时器,那个地方会用到匿名函数。 // fun(函数, number); fun(function(){...}, 5); (3) 对象函数方式(开发中该方式基本不用) 语法: new Function(参数1, 参数2, ..., 函数体); 注意: 参数名称必须使用字符串形式,最后一个默认是函数体且函数体也需要字符串形式。 示例: var fn = new Function("a", "b", "alert(a+b)"); fn(2, 5); -------------------------------------- 2、js函数的参数 (1) 形参没有用var去修饰。 (2) 形参和实参个数不一定要相等。 (3) arguments是一个数组,会将传递的实参进行封装(作用:使传递的多余实参能够派上用场) 示例: function fn(a, b, c) { // var sum = a + b + c; // alert(sum); // arguments是个数组,会将传递的实参进行封装 for (var i = 0; i < arguments.length; i++) { alert(arguments[i]); } } fn(1, 2, 4, 8); -------------------------------------- 3、js函数的返回值 (1) 在定义函数的时候不必表明是否具有返回值。 (2) 返回值仅仅通过return关键字就可以了。return以后的代码不执行了。 示例: function fn(a, b) { return a + b; // alert("xxxx"); // return以后的代码不执行了 } alert(fn(2, 3)); -------------------------------------- 4、js的全局函数(js内置定义好的函数(方法),可以直接调用) (1) 编码和解码函数 encodeURI() 把字符串编码为 URI(常用) decodeURI() 解码某个编码的 URI(常用) encodeURIComponet() 把字符串编码为 URI 组件 decodeURIComponent() 解码一个编码的 URI 组件 escape() 对字符串进行编码 unescape() 对由 escape() 编码的字符串进行解码 三者区别: 进行编码的符号范围不同,实际开发中常使用第一种。 示例: var url = "http://www.baidu.com?name=zhangsan&password=123" alert(encodeURI(url)); // http://www.baidu.com?name=zhangsan&password=123 alert(encodeURIComponent(url)); // http%3A%2F%2Fwww.baidu.com%3Fname%3Dzhangsan%26password%3D123 alert(escape(url)); // http%3A//www.baidu.com%3Fname%3Dzhangsan%26password%3D123 (2) 强制类型转换函数(即通过构造方法传参转换) Number() 把对象的值转换为数字 Boolean() 把对象的值转换为布尔值 String() 把对象的值转换为字符串 注意: 数字类型强转成布尔类型时 非零就是true 零就是false 字符串类型强转成布尔类型时 非空字符串就是true 空字符串("")就是false 布尔类型转数字类型 true转成1 false转成0 字符串类型转数字类型 不能强转 将number\boolean类型转成string类型,已经有了 对象名.toString()方法了,一般不用该类的构造方法了。 (3) 转成数字的函数(方法) parseInt() parseFloat() 注意: 1、boolean类型不能通过上面两种方式转为number类型。 2、string类型可以将数字字符串转换成number类型,例如:"123a3sd5"则转成123。 (4) eval()函数(方法) 作用: 将字符串当作脚本进行解析运行。 示例: var str = "var a = 2; var b = 3; alert(a + b)"; eval(str); // 5 function print(str) { eval(str); } print("自定义的逻辑"); // 相当于代码注入:你写的什么逻辑,它就按照你的什么逻辑执行!那真是太吊了! // function函数相当于一个空壳子,通过外面传进来的字符串的逻辑来解析运行,实现了js的代码注入 注意: java中有代码注入吗? 答:有。 =============================================================================

 

我的GitHub地址:https://github.com/heizemingjun
我的博客园地址:http://www.cnblogs.com/chenmingjun
我的蚂蚁笔记博客地址:http://blog.leanote.com/chenmingjun
Copyright ©2018 黑泽明军
【转载文章务必保留出处和署名,谢谢!】

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
JavaScript函数篇之ES6箭头函数与匿名函数
对于箭头函数,this 关键字始终表示定义箭头函数的对象。
0 0
JavaScript学习笔记(一),js变量、以及函数的调用
JavaScript学习笔记(一),js变量、以及函数的调用
0 0
重温js——函数基础
函数的作用,减少重复代码,实现代码的解耦。把某个功能点给抽离出来。使得代码阅读增加
0 0
JavaScript的函数(二)
JavaScript的函数之自执行函数和闭包 前面讲到js函数的基本分类及使用,今天我们来聊一下自执行函数的原理以及简单闭包原理。 1.自执行函数 说到自执行函数,其实就是函数不用被调用,自身执行代码块代码。整体思路如下代码: 1.按照我们的想法,先声明一个匿名函数,然后在函数后面加上(),但是会发现报错。如下图: 在这里插入图片描述 按照上面的思路去理解,在匿名函数后面直接加上()应该是可以立即执行的,但这个函数报错了,而且报了两个错误,是因为浏览器在解析js代码的时候,遇到function会当做函数声明,然后检查语法,函数声明必须要有函数名,所以报错;第二个括号处的语法错误在于函数
0 0
JavaScript的函数解析(一)
JavaScript的函数 今天和大家说一下js中一个比较重要的内容,函数。 JavaScript 函数是由事件驱动的或者当它被调用时执行的可重复使用的代码块。 JavaScript 函数是被设计为执行特定任务的代码块。 JavaScript 函数会在某代码调用它时被执行。 JavaScript 函数由 function 声明。 JavaScript 函数声明后需要被调用才会执行。 1.无参函数 // 声明函数 function func1(){ console.log("这是一个无参函数"); }
0 0
JavaScript组合函数
JavaScript组合函数
0 0
JavaScript函数柯里化的实现原理,进来教你完成一个自己的自动实现柯里化方法
JavaScript函数柯里化的实现原理,进来教你完成一个自己的自动实现柯里化方法
0 0
【JavaScript】函数式编程——函数柯里化
【JavaScript】函数式编程——函数柯里化
0 0
+关注
黑泽明军
斯人若彩虹,遇上方知有。
文章
问答
文章排行榜
最热
最新
相关电子书
更多
Javascript中的函数
立即下载
JavaScript函数
立即下载
JS零基础入门教程(上册)
立即下载