- alert 来自dom
- 原生js字符串转对象
(1) 使用eval
(2) 使用JSON.parse()
var str1 = "{'a':'1', 'b':'2'}"
var str2 = '{"a":"1", "b:"2"}'
eval('(' + str1+ ')')
// eval可能存在注入的风险
var str3 = '{"a":"1", "b:"2"}'
// 使用JSON.parse转换字符串与对象,str1外双引号,内单引号,出现报错
JSON.parse(str3)
// 结果
{a: "1", b: "2"}
- 回调函数可以是异步也可以是同步
function Person(){
this.answer = function(){
console.log("i am answering other questions");
};
this.think = function(callback){
console.log("thinking---")
setTimeout(function(){
callback();
}, 5000);
}
}
var person = new Person();
person.think(function(){
console.log("thinking 5 seconds get the right answer");
})
person.answer();
- 直接赋值&引用赋值
var a={"name":"xiaoming", "age":13}
var b=a;
//b 结果
{name: "xiaoming", age: 13}
//a 结果
{name: "xiaoming", age: 13}
a.name="xiaohong"
//b 结果
{name: "xiaohong", age: 13}
//a 结果
{name: "xiaohong", age: 13}
b.age=15
//b 结果
{name: "xiaohong", age: 15}
//a 结果
{name: "xiaohong", age: 15}
// 对象地址和数据分开存储,分别存储在栈和堆中
// 因为a赋值给b的并不是对象,是指向对象存储的地址,所以a和b指向同一个地址,这个地址对应的对象改变时,a,b均改变
- node 的 exports和module.exports区别
// module.exports 和 exports 都可以导出对象,Array,函数等,
// 但是不能
exports = {
"a": function(){console.log("a")},
"b": function(){console.log("b")}
}
// 可以
module.exports = {
"a": function(){console.log("a")},
"b": function(){console.log("b")}
}
// 可以
exports.a=function(){console.log("a");
exports.b=function(){console.log("b");
下面截图来自:(https://www.liaoxuefeng.com/wiki/1022910821149312/1023027697415616)