• javascript深入浅出——学习笔记(包装对象和类型检测)


    3包装对象:https://www.imooc.com/video/5676

        当我们尝试把基本类型已对象的方式访问时,javascript会把该基本类型转换为对应的包装类型对象(临时对象),相当于new了一个新对象,且新对象的值和原基本类型一样,当完成访问和操作,临时对象会被销毁掉。

        var a="string";

        alert(a.length);//6

        a.t=3;//成功未报错

        alert(a.t);//undefined   临时对象已被销毁

        ‘str’----String Object

        123----Number Object

        true---Boolean Object

    4类型检测:https://www.imooc.com/video/5677

        类型检测:

          typeof  返回字符串,适合函数对象(返回“function”)和基本类型的判断

          instanceof      判断对象类型,基于原型链判断  期望左操作数为对象,若不是对象是基本类型则直接返回false,期望右操作数必须是一个函数对象或者说函数构造器,若不是则会抛出typeerror异常。instanceof原理,判断左操作数的原型链上是否右边构造函数的prototype属性。

          //https://www.ibm.com/developerworks/cn/web/1306_jiangjj_jsinstanceof/

          Object.prototype.toString

          constructor

          duck type

        

            typeof 100 ——‘number’

            typeof true——‘boolean’

            typeof function——‘function’

            typeof undefined——‘undefined’

            typeof new Object()——‘object’

            typeof [1,2]——‘object’

            typeof NaN——‘number’

            typeof null——‘object’

        

            [1,2] instanceof Array===true

            new Object() instanceof Array===false

     

      任何一个构造函数都会有一个prototype对象属性,这个对象属性,将用于new出的对象的原型_proto_。

      对象实例的原型(_proto_)指向,对应构造函数的prototype

      不同window或iframe间的对象类型检测不能使用instanceof

    Object.prototype.toString   

      Object.prototype.toString.apply([])==='[object Array]';

      Object.prototype.toString.apply(function(){})==='[object Function]';

      Object.prototype.toString.apply(null)==='[object Null]';

      Object.prototype.toString.apply(undefined)==='[object Undefined]';

      IE6/7/8 Object.prototype.toString.apply(null)返回‘[object Object]’

    任何一个对象都有constructor属性(constructor属性继承自原型)指向构造这个对象的构造器或函数,constructor可以被改写,所以使用的时候需要注意。

    duck type 通过一些特征,判断一个对象是否属于某些类型。

    类型检测小结:

    typeof——

      适合基本类型和function的检测,遇到null失效(typeof null------object)

      可以用严格等于的方式判断null

    Object.prototype.toString——

      适合基本类型,函数数组的判断

       

  • 相关阅读:
    对比<input type="text" id="">和<asp:TextBox runat="server" ID="">
    EasyUI 启用行内编辑
    水平居中和transform: translateY(-50%) 实现元素垂直居中效果
    表头的一些解释
    <%@ Page Language="C#" AutoEventWireup="true" CodeFile="Login.aspx.cs" Inherits="Login" %>
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">详解
    访问远程桌面 步骤
    jQuery EasyUI API 中文文档
    用JavaScript方式创建easyUI datagrid Column Group(列组)
    jquery中innerheight outerHeight()与height()的区别
  • 原文地址:https://www.cnblogs.com/em2464/p/8877396.html
Copyright © 2020-2023  润新知