js 相关知识点记录

  1. alert 来自dom
  2. 原生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"}
  1. 回调函数可以是异步也可以是同步
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();
  1. 直接赋值&引用赋值
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均改变

  1. 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)
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值