博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
11.22复习JS,浏览器内核
阅读量:6691 次
发布时间:2019-06-25

本文共 1687 字,大约阅读时间需要 5 分钟。

Js中级复习

  1. this js的关键字,

用途:指向某一个对象。

如何判断this指向

函数(方法)内

一种以函数的方式调用(不带.) this指向winodw

一种以方法的形式调用(函数名前面带.)this指向点前面的

函数(方法)外,this指向window

This指向的特列

  1. 自调用函数内的this都是window
  2. 定时器的this指向window
  3. 事件里面的this 指向触发事件的元素
  4. 构造函数里的this指向他的实例

 

  1. 怎样替换函数内的this

(1)      Call()

(2)      Apply

(3)      Bind()

  1. fn.call(B,5) B取代了fn中的this并把fn调用了。

Call和apply,bind只能是函数(方法)或者函数对象的

var a=45;

    var b={

        a:12

    }

    var arr=[12,56]

    function fn(){

        console.log(this.a)

    }

    fn.call(b)  call前面必须是函数对象,其他的不行

2.面向对象

1.单例模式

Var obj={}

2.工厂模式

function fn(){

Var obj={}

obj.name=”zhang”

return obj;

}

  1. 构造函数  三个特点  函数名首字母大写 函数的属性前面加this

函数调用用new 调用

function Person(name){

this.name=name

}

Var zhang=new Person(“zhang”)

1.每个构造函数天生自带一个prototype的属性,叫原型,他是一个对象,存放父类可继承的属性

2.函数内的属性是子对象天生就继承的,不需要任何操作

3.prototype上的属性是继承给子对象的,子对象必须通过__proto__(原型链)来查找

4.每个子对象都有一个__proto__,它指向父类的原型。

原型链:

子对象再操作一个属性时,首先看属性是私有的,有就直接用,没有就通过__proto__向子对象的父类查找,父类有就使用,没有就用父类的__proto__继续向上查找,知道基类Object,如果基类没有就是undefined

Object.prototype.sex="男男女女"

    function Person(){

        this.name="张三"

    }

    Person.prototype={

        age:"456"

    }

    var zhang=new Person()

    console.log(zhang.sex)

 

  1. 作用域和作用域链

浏览器客户端给js一个生存环境。

Js代码再执行之前,浏览器会给js一个生存环境就window。

他会分成两个模块,一个就内存,一个叫执行。内存模块在代码执行前就完成了,存放关键字var和function,每存放一个变量就会生成一个内存地址。

 

在执行模块 a=12; 先通过内存地址查找有没有a,有就直接赋值给a,没有就是undefined

赋值

  1. 基本数据类型 就直接赋值
  2. 引用数据类型 把内存地址赋给变量

var obj={

        name:"zhangsan"

    }

    var person=obj;

    person.name="lisi"

    console.log(obj.name)

 

基本数据类型在赋值的时候就是简单的操作值

引用数据类型在赋值的时候,把内存地址赋值给变量,在操作引用数据类型的时候,首先通过内存地址去找到里面的东西,然后操作。

(引用数据类型在赋值的时候,首先开辟一个堆内存,存放里面的代码块,然后把内存地址赋值给变量。在操作这个变量时候会通过内存地址去查找,然后修改里面的东西)

引用数据类型 object  array  function 前两个都是以键值对的形式存放,而后一个以字符串的形式存放。

四大内核:

  1、Trident内核,也称IE内核。
  2、Webkit内核。
  3、Gecko内核。
  4、Presto内核

转载于:https://www.cnblogs.com/lizi-1com/p/10038197.html

你可能感兴趣的文章
GL_Oracle Erp常用的报表(汇总)
查看>>
使用javacv,解码socket接收的H264码流(byte[]),转为yuv处理,最后再合成转为H264...
查看>>
长春理工大学第十四届程序设计竞赛(重现赛)I
查看>>
corosync+pacemaker部署高可用集群
查看>>
利用Fidder工具抓取App数据包
查看>>
jQuery中 prop 与 attr 方法的区别
查看>>
jsp中遇到Integer的方法valueOf()和parseInt()的区别.前者要求是对象类型,后者是数字型字符串...
查看>>
java实例三维空间求点之间的距离。。。。
查看>>
java中I/O类
查看>>
JDBC(一)
查看>>
药房相关
查看>>
selectByExampleWithBLOBs-----搜索结果包含大字段类型----搜索结果包含大字段类型
查看>>
IT领域的罗马帝国——微软公司
查看>>
优化MySchool数据库(二)
查看>>
基于vue-cli的改造的多页面开发脚手架
查看>>
深入剖析Tomcat(2)
查看>>
<ubuntun中文>读书笔记
查看>>
GUI
查看>>
call for paper
查看>>
leetcode — unique-binary-search-trees-ii
查看>>