查看文章前你需要了解以下2点:
//1.this指向的是windows对象,通过console.log(this)可以查看到对象包含所有的方法和属性
//2.全局变量属于this对象的属性通过console.log(this)可以查看到对象包含我们设置的全局变量
我们经常在创建相同结构的Js对象会重复的设置对象属性和方法,造成太多的冗余代码,例如下面:
var box1=new Object(); box1.name='张三'; box1.age =14; var box2=new Object(); box2.name='李四'; box2.age =15;
我们为什么不用赋值的方式重写呢?因为对象属于引用类型,赋值后2个变量依旧引用同一个内存地址,一个发生变化,另一值也发生了变化。于是有了工厂模式
function createobject(name,age){
var obj=new Object();
obj.name=name;0
obj.age=age;
obj.run=function(){
return this.name+'--'+this.age;
}
return obj;
}
var box1=createobject('高久峰',23);
var box2=createobject('某美女',24);以上的工厂模式只是封装一个创建对象的方法,工厂模式的确解决的创建多个对象的问题,但是缺点是我们无法识别对象,因为它们都从属于Object对象。解决这个问题可以看看js构造函数文章。本站搜索。
开发需求如下,商品下单后需要指定送到日期:送达日期为周一 周三 周六 ,如果今天周一,用户选择周一即为下一周周一。代码如下:<html> <head> <meta charset="utf-8"> <title>...
<!doctype html> <html> <head> <meta charset="utf-8"> <title>无标题文档</title> <script type...
//字面量的形式创建原型对象 /* function Box(){} Box.prototype={ 'name':'gao', age:23, fun:function(){ return this.name+'--'+...
//原型的缺点 function Box(){} Box.prototype={ 'name':'gao', age:23, family:['哥哥','姐姐','妹妹'], &...
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>录制</title> <script ...
rem原理和简介(1).字体单位单位的值是根据html根元素大小而定,同样可以作为宽度高度单位(2).适配原理将px替换为rem,动态修改html的font-size适配(3).单位1rem=16px,why? F12中1rem在computed中font-size属性中会显示为font-size:...