只有函数才有 prototype属性
内置函数都没有prototype toString
_ _内部私有开头
typeof Function.prototype //function//函数是js中的一等公民
修改了原型的指向,就没有任何方法能够访问到默认的原型对象了
Object 中的成员介绍
constructor 属性 : 指向当前的构造函数
Object.prototype.constructor===Object
hasOwnProperty
has 有没有 own自己 property属性
作用:判断属性是不是对象自身提供的,如果是就返回 true
obj.hasOwnProperty(''age)
ifPrototypeOf
是不是属性的
语法: 原型对象.isPrototypeOf(实例对象)
作用:判断前面的对象是不是参数对象的原型对象;如果是就是true
propertyIsEnumerable
属性是不是可枚举的 (是否可遍历)
语法: 对象.propertyIsEnmerable(属性)
作用: 1.属性必须是对象自身提供的
2.这个属性是可被枚举的(可以通过for-in循环遍历出来)
同 hasOwnProperty
ES5新
var obj={}
Obiect.defineProperty(obj,'name',{
value:'小刚',//修改值
enumerable:true, //控制当前name属性是否可枚举
writable:false, 是否可写
configurable:false //是否可配置
})
locale
toLocaleString //转化为本地内容
toString //转换为字符串
valueOf //转化为值
在将一个对象进行计算的时候先调用valueOf 再调用toString
instanceof 运算符
语法:实例对象 instanceof 构造函数
作用:用来检测 构造函数prototype属性的值 是否在被检测对象
的原型链 如果在返回true
规律: 在创建对象以后,没有修改prototype的值,那么结果为true
//Object.prototype是在任意一个对象的原型链上,所以结果为true
console.log( 任意对象 instanceof Object) //true
增删改查 CRUD (增加 读取 更新 删除)
JSON.stringify(数组)
toString.call(arr) //判断是不是数组
判断是不是数组的方式:
ES5: 1.Array.isArray()
2.toString.call(arr) // [object Array] / jQuery
3.insanceof //不严谨
______________________________________________
面向对象的方式组织代码:
1.属性放到构造函数中
typeof Object //func
函数也是对象 (函数对象)
//大写Function的使用
var fn =new Function('参数1','参数2','函数体');
1.参数都是字符串 类型的
2.最后一个函数表示函数体
3.前面所有的参数,都表示新创建函数的参数
eval
eval() //相当于小型的词法解析器
将字符串解析为代码来执行,参数是字符串
eval('var num=123;'); //模板引擎 可能用到eval/或 new Function
模板引擎的原理: new Function()
var jsonStr='{}'
将JSON字符串转化为 js对象
eval("("+jsonStr+")")
eval('var obj'='+jsonStr'); //
对于if来说 如果后面只有一句话 {} 可以省略 {}被解析为代码块
将多行代码整合到一起,受到if的控制
{} 在js中有两种解析方式
1.被解析为:代码块 2.被解析为:对象字面量
具体解析哪一种,是由js引擎 词法分析 的结果
() 中出现的内容只能是表达式
(function(){})(); //()的作用将函数声明解析为函数表达式
代码块中不允许出现 : 冒号
Function 和 eval 的区别和联系:
相同点:都能够将字符串当作代码来执行
不同点:
考虑性能使用 eval
考虑安全性使用 Function
这俩个方法:比普通代码慢很多
________________________________________________
函数的原型链:
1.只有函数才有 prototype 属性
2.只要是对象就有 __proto__属性
如果是查看 prototype 属性,此时函数看作是构造函数
如果是查看 __proto__ 属性,此时就把函数看作是对象
fn对象的原型链
fn -> Function.prototype -> Object.prototype -> null
所有的函数的原型链都是这个结构
访问函数的属性:fn.toString
alert 也是函数
js中只有大写的Function __proto__ 和 prototype指向了同一个对象
console.log(Function.__proto__===Function.prototype) //true
Object.prototype 是所有对象的根
Function.prototype是所有函数的根
笔记重点:
1. instanceof 运算符
用来检测 构造函数prototype属性的值,是否在被检测对象的
原型链上,如果在就是true
2. 歌曲列表管理中 (使用面向对象组织代码的形式)
属性放在构造函数中
方法放在原型对象中
3. Function 和 eval
4. 完整的原型链
5.检测数组的三种方式
Array.isArray()
Object.prototype.toString.call([])
instanceof()
笔记连载中 , 温故而知新!
内置函数都没有prototype toString
_ _内部私有开头
typeof Function.prototype //function//函数是js中的一等公民
修改了原型的指向,就没有任何方法能够访问到默认的原型对象了
Object 中的成员介绍
constructor 属性 : 指向当前的构造函数
Object.prototype.constructor===Object
hasOwnProperty
has 有没有 own自己 property属性
作用:判断属性是不是对象自身提供的,如果是就返回 true
obj.hasOwnProperty(''age)
ifPrototypeOf
是不是属性的
语法: 原型对象.isPrototypeOf(实例对象)
作用:判断前面的对象是不是参数对象的原型对象;如果是就是true
propertyIsEnumerable
属性是不是可枚举的 (是否可遍历)
语法: 对象.propertyIsEnmerable(属性)
作用: 1.属性必须是对象自身提供的
2.这个属性是可被枚举的(可以通过for-in循环遍历出来)
同 hasOwnProperty
ES5新
var obj={}
Obiect.defineProperty(obj,'name',{
value:'小刚',//修改值
enumerable:true, //控制当前name属性是否可枚举
writable:false, 是否可写
configurable:false //是否可配置
})
locale
toLocaleString //转化为本地内容
toString //转换为字符串
valueOf //转化为值
在将一个对象进行计算的时候先调用valueOf 再调用toString
instanceof 运算符
语法:实例对象 instanceof 构造函数
作用:用来检测 构造函数prototype属性的值 是否在被检测对象
的原型链 如果在返回true
规律: 在创建对象以后,没有修改prototype的值,那么结果为true
//Object.prototype是在任意一个对象的原型链上,所以结果为true
console.log( 任意对象 instanceof Object) //true
增删改查 CRUD (增加 读取 更新 删除)
JSON.stringify(数组)
toString.call(arr) //判断是不是数组
判断是不是数组的方式:
ES5: 1.Array.isArray()
2.toString.call(arr) // [object Array] / jQuery
3.insanceof //不严谨
______________________________________________
面向对象的方式组织代码:
1.属性放到构造函数中
2.公共的方法或属性放到原型
typeof Object //func
函数也是对象 (函数对象)
//大写Function的使用
var fn =new Function('参数1','参数2','函数体');
1.参数都是字符串 类型的
2.最后一个函数表示函数体
3.前面所有的参数,都表示新创建函数的参数
eval
eval() //相当于小型的词法解析器
将字符串解析为代码来执行,参数是字符串
eval('var num=123;'); //模板引擎 可能用到eval/或 new Function
模板引擎的原理: new Function()
var jsonStr='{}'
将JSON字符串转化为 js对象
eval("("+jsonStr+")")
eval('var obj'='+jsonStr'); //
对于if来说 如果后面只有一句话 {} 可以省略 {}被解析为代码块
将多行代码整合到一起,受到if的控制
{} 在js中有两种解析方式
1.被解析为:代码块 2.被解析为:对象字面量
具体解析哪一种,是由js引擎 词法分析 的结果
() 中出现的内容只能是表达式
(function(){})(); //()的作用将函数声明解析为函数表达式
代码块中不允许出现 : 冒号
Function 和 eval 的区别和联系:
相同点:都能够将字符串当作代码来执行
不同点:
考虑性能使用 eval
考虑安全性使用 Function
这俩个方法:比普通代码慢很多
________________________________________________
函数的原型链:
1.只有函数才有 prototype 属性
2.只要是对象就有 __proto__属性
如果是查看 prototype 属性,此时函数看作是构造函数
如果是查看 __proto__ 属性,此时就把函数看作是对象
fn对象的原型链
fn -> Function.prototype -> Object.prototype -> null
所有的函数的原型链都是这个结构
访问函数的属性:fn.toString
alert 也是函数
js中只有大写的Function __proto__ 和 prototype指向了同一个对象
console.log(Function.__proto__===Function.prototype) //true
Object.prototype 是所有对象的根
Function.prototype是所有函数的根
笔记重点:
1. instanceof 运算符
用来检测 构造函数prototype属性的值,是否在被检测对象的
原型链上,如果在就是true
2. 歌曲列表管理中 (使用面向对象组织代码的形式)
属性放在构造函数中
方法放在原型对象中
3. Function 和 eval
4. 完整的原型链
5.检测数组的三种方式
Array.isArray()
Object.prototype.toString.call([])
instanceof()
笔记连载中 , 温故而知新!