• 《js高程》笔记总结一:基本概念(语法,数据类型,流程控制,函数)


    1.ECMA 欧洲计算机制造商协会

    2.";"的作用

    • 代码后的;当压缩代码时可以用于压缩代码,有效的间隔开代码。

    3.数据类型有 undefined,null,boolean,string,number,object

    4.typeof操作符

    • 检测给定变量的类型,那检测函数会返回什么

    5.boolean

    • 可以对任何数据类型的值调用Boolean()函数
    • ECMAScript中所有类型的值都有与这两个boolean值相对应的值
    • string : 任何非空字符串(true) ----- " "(false)
    • number : 任何非零数字值(true) ----- 0和NaN(false)
    • object :任何对象 (true)---- null (false)
    • undefined: 不适用 ---- undefined(flase)

    6.null 和undefined的区别,

    • null: 空对象指针(car=null typeof car 为object)
    • undefined: 没有被定义的变量
    • 无论什么情况都没有必要把一个变量的值显示为undefined,但是只要意在保存对象的变量还没有真正保存为对象,就有必要让该变量保存null值
    • 但是 if(null == undefined) //true (undefined派生自null)

    7.number :

    • 8进制数以0开头, 16进制数都要使用0x开头
    • 浮点数值(必须包含一个小数点,并且小数点后面必须有一位数字) 由于浮点数值占用的内存空间是整数值的两倍,所以当数值为类似于1.0的时候,ECMA会自动将浮点数值转化为整数值
    • e的用法 var a=3.12e5 //312000
    • 为什么0.1+0.2 != 0.3
    • NaN :1.任何设计NaN的操作都会返回NaN 2.NaN于任何值都不相等,包括他自己
    • isNaN()函数,作用即名字意思,放入参数后他会先尝试转化为数值,如 “10” 或者boolean值 。他还适用于对象,会自己调用对象的value()函数判断返回值,和调用tostring()方法
    • 三个把数值转化非数值转化成数值的函数 ,Number(),parseInt(),parseFloat(),可以转化字符型数字和boolean值

    8.string:

    字符字面量

    • (换行) (制表) (退格 (回车)f(进纸) (斜杠) '(单引号) "(双引号) '' hei '' (表示字符'hei')
    • xnn(以十六进制的代码nn表示的一个字符,n为0-f ,x41表示A
    • unnn(以十六进制代码nnn表示的一个unicode字符 u03a3表示一个希腊字符)
    • 这个字面量都被作为一个字符在解析
    • var text="this u030a3" texi.length为5个字符

    字符串的特点

    • 字符串一旦创建,他的值就不能更改
    • var lang="java" lang=lang+"scrpit"
    • 实现过程:先创建容纳10个字符的新字符串,然后填充"java","script",然后销毁这两个字符串

    转化为字符串

    • tostring()方法,每个字符串都有自己的tostring方法,但是null和undefined没有这个方法,当数值调用tostring方法的时候可以,可以加入参数,如,tostring(16),先转化为16进制的数值字符串
    • string()方法,如果值有tostring()方法,调用tostring()。当不知道要转换的值是不是null和undefined的时候,可以用string方法,null转化为"null" ,undefined转化为"undefined"
    • 所以string(1)的时候,其实是在调用tostring()。

    9.object类型

    • var obj = object();
    • EMCAScript中的对象其实就是一组数据和功能的集合
    • object类型是所有他的实例的基础,object类型所具有的任何属性和方法也同样存在于更具体的对象中
    • object每个实例都具有下列的属性和方法
      • constructor:保存着用于创建当前对象的函数。对于上面的例子,构造函数(curstructor)就是object()。
        + hasOwnProperty(PropertyName):用于检测给定的属性在当前对象实例中(而不是原型中)是否存在,其中,作为参数的属性名(PropertyName)必须以字符串的形式指定(obj.hasOwnProperty("name")).
      • isPrototypeOf(object):用于检测传入的对象是否是当前对象的原型
      • propertyIsEnumberable(PropertyName):用于给定的属性是否能够使用for-in语句来枚举,与hasOwnProperty()方法一样,作为参数的属性名必须以字符串形式指定
      • toLocaleString():返回对象的字符串表示,该字符串与执行环境的地区对应。
      • toString():返回对象的字符串表示
      • valueof() :返回对象的字符串,数值,或者布尔值。通常与toString()方法的返回值相同

    10.操作符

    一元操作符(只能操作一个值): ++ --

    位操作符

    • 位操作符用于在最基本的层次上
    • ECMAscript中所有的数值都以IEEE-754 64位格式存储,但是位操作符并不直接操作64位的值。

    而是,先将64位的值转化为32位,然后进行操作,在讲32位的值转化位64位,由于64位的存储格式是透明的,因此整个过程就像只存在32位的整数一样

    • 数值18:00000000000000000000000000010010
    • 负数同样用以二进制补码来存储,但是使用的格式是二进制补码
    • 数值-18:
    • 先求得18的二进制码
    • 然后求18二进制码的反码(将0转换成1,1转换成0)

    还有一些关于位操作符的知识就不在这里概述了

    布尔操作符

    在一门编程语言中,布尔操作符的重要性堪比相等操作符,如果没有测试两个值关系的能力,那么诸如if。。。else和循环之类的语句就不会有用武之地。

    • 布尔操作符一共有三个:非(not),与(and),或(or)
      • 逻辑非操作符(!)
      • 逻辑与操作符(&&)
      • 逻辑操作符(||)

    乘性操作符

    • 表示两个数的乘积
    • 如果成绩超过了ECMAScript数值的表示范围,则返回Infinity(存放正无穷大的数值)或者-Infinity(存放负无穷大的数值)
    • 如果操作的不是一个数值,则会在后台先调用Number()看能不能将其转换为数值。

    除,加,减操作符规则类似

    关系操作符( <, >,<=,>=四种)

    • 这几个操作符都返回布尔值
    • 当比较字符串的时候,会比较字符串的第一个字符的编码值的大小
    • (var a="23" < "3")//true 因为"2"的字符编码小于"3"
    • (var b= "Bas"< "apache" ) //true 因为大写字母的字符编码全部小于小写的字符编码
    • (var c= "3" <2)//false 字符比较中有数字的时候,字符会被先转换成数字

    相等操作符

    • 相等(== )和不相等(!=)
      • 相等和不相等这两个操作符都会强制转型,然后比较他们的相等性
      • 如果一个操作符是对象,另一个不是,则调用对象的valueOf()方法,然后比较
      • 如果是两个对象,则比较他们是不是指向同一个对象。
    • 全等和不全等

    条件操作符(三元运算符)

    赋值操作符

    • 复合操作符:(*=,/=,+=,-=,<<=,>>=)

    11.语句

    • if语句

    • do-while语句

      • 后测试循环语句,循环体内的代码至少循环一次
      • do { i++ } while (i<10)
    • while语句

      • while(){}
    • for语句

    • for-in语句

      • 精准的迭代语句,通常用来枚举对象的属性
      • for(var name in window) {document.write(name)}
      • 遇到null和undeined会报错,但是在es5中被修正,对这种情况不再执行循环体
    • label语句

      • 使用label语句可以在代码中添加标签,以便将来使用
      • label通常配合其他循环语句一起使用
      • var num=0;
        outermost:
        for(var i=0;i<10;i++){
            for(var j=0;j<10;j++){
                if(i == 5 && j == 5){
                    break outermost;
                }
                num++;  //55
            }
        }
        
    • with语句

      • 将代码的作用域设置到一个特定的对象中(一般不使用)
    • swich语句

      • switch(参数){
            case value : 执行体 ;
            break;
            case value :执行体;
            break;
            default :执行体;
        }
        
      • 虽然js中switch语句借鉴了其他语言,但是这个语句在js中也有他自己的特色,他能够使用任何数据类型,而且case的值不一定是常数,还可以是表达式
      • switch("hello"){
            case "he"+"llo":alert(yes);
            break;
            case "hh"+"llo":alert(no);
            break;
        }
        
      • var num =25;
        switch(true){
            case num <0 : alert("小于0");
            break;
            case num >=0 && num<=10 :alert("在0和10之间");
            break;
        }
        
        这里之所以给switch语句传递表达式true,是因为每个case值都可以返回一个布尔值,这样,每个case都会按照顺序被执行,知道遇到default为止

    12.函数

    • 严格模式对函数的限制:
      • 1.不能把函数和参数命名为eval和argument
      • 2.不能出现两个命名参数同名的情况
    • 理解参数
      • 与其他语言不同,js并不介意传递进多少个参数,因为js内部是用一个数组来表示的,函数接收到的始终是一个数组,而不关系数组里的参数
      • arguments对象:
        • arguments和数组很像,但是并不是Array的实例
        • arguments可以使用放括号语法访问它的每一个元素
        • arguments的值永远与对应命名参数的值保持同步
    • js中没有重载,但是,他却能同过arguments对象和其他的方法来实现重载的功能
  • 相关阅读:
    小能客服
    bootstrap 字体图标
    在线绘图(PS)(海报)
    UI教程
    免费在线设计网站
    测量史上首个易语言工程测量模块
    在ado.net中实现oracle存储过程调用两种方式
    VS一些快捷键
    解决Win10家庭版没有‘本地用户和组’问题
    参照示例搭建一个Quertz + Topshelf的一个作业调度服务(基础)
  • 原文地址:https://www.cnblogs.com/JCDXH/p/11603111.html
Copyright © 2020-2023  润新知