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) 检索字符串中指定的值。返回 true 或 false
        示例:
            校验邮箱:
                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中有代码注入吗?
                答:有。 
=============================================================================

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏互联网杂技

javascript大法好,不用记

数组的操作 ---- Array.prototype.toString ( ) 把数组转变为字符串,返回字符串,arr.toString(); ---- Arr...

37370
来自专栏Java与Android技术栈

Scala学习笔记(六)

偏函数(Partial Function),是一个数学概念它不是"函数"的一种, 它跟函数是平行的概念。 Scala中的Partia Function是一个T...

8820
来自专栏PPV课数据科学社区

一文读懂如何用 Python 实现6种排序算法

原文链接:https://my.oschina.net/liuyuantao/blog/749329 总结了一下常见集中排序的算法 ? 归并排序 归并排序也称合...

38470
来自专栏待你如初见

Day11

for(元素的数据类型 变量名 : 数组名或者Collection集合对象名) {

11460
来自专栏CDA数据分析师

一文读懂如何用 Python 实现6种排序算法

总结了一下常见集中排序的算法 ? 归并排序 归并排序也称合并排序,是分治法的典型应用。分治思想是将每个问题分解成个个小问题,将每个小问题解决,然后合并。 具体...

22390
来自专栏软件开发 -- 分享 互助 成长

(虚)继承类的内存占用大小

(虚)继承类的内存占用大小 首先,平时所声明的类只是一种类型定义,它本身是没有大小可言的。 因此,如果用sizeof运算符对一个类型名操作,那得到的是具有该类...

22180
来自专栏柠檬先生

python基础 面向对象编程

面向对象编程的基本思想   类和实例     类用于定义抽象类型     实例根据类的定义创建出来 python 定义类并创建实例   在python 中,通过...

27840
来自专栏Create Sun

基础拾遗------委托详解

前言:   C# 中的委托(Delegate)类似于 C 或 C++ 中函数的指针。委托是存有对某个方法的引用的一种引用类型变量。引用可在运行时被改变。委托(D...

32680
来自专栏程序员的知识天地

python 实现各种排序算法

归并排序也称合并排序,是分治法的典型应用。分治思想是将每个问题分解成个个小问题,将每个小问题解决,然后合并。

8910
来自专栏浪淘沙

java初级笔记----API

一、类Object java.lang.Object 是类层次结构的根类,每个类都使用object作为超类。所有对象(包括数组)都实现这个类...

15640

扫码关注云+社区

领取腾讯云代金券