obj的方法调用,所以函数体中的this就代表obj对象 2.函数调用模式 当一个函数并非一个对象的属性时,那么它就是被当做函数来调用的。...,所以函数体中的this代表window对象。 ...3.构造函数模式 如果在一个函数前面加上new关键字来调用,那么就会创建一个连接到该函数的prototype成员的新对象,同时,this会被绑定到这个新对象上。...这种情况下,这个函数就可以成为此对象的构造函数。...4.apply调用模式 在JS中,函数也是对象,所有函数对象都有两个方法:apply和call,这两个方法可以让我们构建一个参数数组传递给调用函数,也允许我们改变this的值。
总结 ---- 前言 在Node.js中提供了一些全局可用的变量、函数和对象,全局就是不需要进行模块加载,可以直接使用的。其中包括全局作用域的函数和对象。...也包括不在全局作用域,而在每个模块作用域都存在的变量、函数和对象,在全局可用,但不是golbal对象的属性。...---- _dirname和_filename变量 Node.js提供了两个与文件操作相关全局可用变量_dirname和_filename变量。...setImmediate(cb) 用于延迟调用cb函数。cb将在I/O事件回调之后,setTimeout和setInterval回调之前调用。...console.dir(obj[,options]) 用来对一个对象进行检查,并以易于阅读和打印的格式显示。 console.time(label) 输出时间,表示计时开始。
学习JS的过程中,想要掌握面向对象的程序设计风格,对象模型(原型和继承)是其中的重点和难点,拜读了各类经典书籍和各位前辈的技术文章,感觉都太过高深,花费了不少时间才搞明白(个人智商是硬伤/(ㄒoㄒ)/~...一、基本概念 1、对象:属性和方法的集合,即变量和函数的封装。每个对象都有一个__proto__属性,指向这个对象的构造函数的原型对象。 ...3、原型对象:每个函数都有一个prototype属性,它是一个指向原型对象的指针(原型对象在定义函数时同时被创建) 二、创建对象的方法 1、使用构造函数和原型对象共同创建 ?...通过构造函数创建实例对象p1和p2的时候,其中name、age、job这些是通过构造函数生成的(本地部分),sayName方法是通过继承原型对象来实现共享的(远程部分),这样多个实例对象都是由本地(私有...如上图,使用Object.create方法从原型对象直接生成新的实例对象,新对象p1继承原型对象的属性和方法,但是这里没有用到构造函数 var person={ classname:'human'}/
JS对象,是一个名值对的无序集合。 jquery对象,是jquery特有的对象,只有调用jquery框架才存在。其实jquery对象,也是一种js对象。...jquery对象和js对象可以相互转换,例如 $("#div").get(),即可以把一个jquery对象转换为js对象。...最主要的区别,js对象上的方法,不能直接用在jquery对象上,如果一定要给jquery对象使用js对象的方法,必须把jquery对象转换为js对象。...jquery对象,则可以随意使用jquery定义的方法。
有一个函数很短,比如这样: function getData() { return { data: 1 } } console.log(getData()) // { data: 1 } 想用...ES6箭头函数语法简化一下,于是写成这样: const getData = () => { data: 1 } console.log(getData()) // undefined 怎么会是呢?...解析 根本原因在于这一段: const getData = () => { data: 1 } 如果用传统function来写,和下面是等价的: function getData() { data...j++) { if (j == 2) { break outer } } } console.log(i, j) // 0 2 果然和Java
背景 我没有系统性的从头开始学过一遍JS,全凭之前学的其它语言,尤其是Python,直接上手操作了,所以留了不少的坑。 虽然对我来说是一个坑,但我觉得本文更适合放到学习的分类里。 给出下列代码。...这里的foo是obj对象的实例方法,es6语法: 'use strict' function call(func) { func() } const obj = { foo() {...call(obj.bar) # 这里的原因就是,当我们使用obj.bar这样获得方法的话,Python会给我们把obj和第一个参数...解决方案 我们需要进行一个操作,如果也想像Python那样: Function.prototype.bind() bind() 方法创建一个新的函数,在 bind() 被调用时,这个新函数的 this...被指定为 bind() 的第一个参数,而其余参数将作为新函数的参数,供调用时使用。
Person("zs", 44); obj2.say(); console.log(obj2.currentType); /** * prototype的特点:存在在原型对象里面的属性与方法可以被构造函数的所有对象所共享...);//构造函数里面的prototype指向了对象(原型对象) /*2.每个"原型对象"中都有一个默认的属性, 叫做constructor constructor指向当前原型对象对应的那个..."构造函数" */ console.log(Person.prototype.constructor);//原型对象里面的constructor属性指向了函数(当前原型对象对应的那个..."构造函数") /*3.通过构造函数创建出来的对象我们称之为"实例对象" 每个"实例对象"中都有一个默认的属性, 叫做__proto__ __proto__指向创建它的那个构造函数的...__proto__);//实例对象的__proto__指向了对象(构函数里面的原型对象) ?
本期介绍 本期主要介绍DOM对象&JS事件总结&全局函数 文章目录 1. DOM 对象 1.1 DOM 对象是什么?有什么作用? 1.2 DOM 树介绍 1.3 DOM 和 BOM 关系 2. ...JS 事件总结 3. 全局函数(global) 3.1 执行 3.2 编码和解码 3.3 字符串转数字 1. DOM 对象 1.1 DOM 对象是什么?有什么作用?...DOM 对象。...document 一个 HTML 文档加载到内存中就会形成一个 DOM 对象 1.3 DOM 和 BOM 关系 BOM 包含了 DOM 对象 1.4 节点属性 2. ...JS 事件总结 常见事件 示例代码: 鼠标键盘事件 示例代码: 3. 全局函数(global) 3.1 执行 作用:用于增强程序的扩展性。
js中关于原型和原型链有 __proto__ 、prototype、constructor 频频出现在面试题中,但是记得多了反而容易记混。 这里简单总结下每个属性的使用场景,方便记忆。...对象和函数都有 __proto__,对象的 __proto__指向构造函数的prototype,构造函数的__proto__指向 Function.prototype 对象和函数都有constructor...,对象的 constructor指向构造函数,构造函数的constructor指向 Function 函数才有 prototype 函数的prototype又是一个对象,但是 Funtion.prototype...特殊记忆:typeof Function.prototype==="function" Object因为O大写,可以看出本质也是一个构造函数 __proto__ 指向一个原型对象,构造函数.prototype...__proto__===null,因为 Object.prototype 为js 原型链的顶端。
做项目的时候遇到一个不是很常见的问题,就是js函数传递参数的时候,我们一般是传递一个数字或者是一个字符串,但是当你的需求满足不了的时候,就需要将对象或者数组作为一个参数传递过去,这个时候怎么做呢,今天简单的说有一下...这个是典型的三层的json结构,所以遍历的难度是不大的,就是很容就遍历出错,我的需求当然不是说仅仅将这些数据遍历出来就可以了,我需要做的是将最里层的data拿到,作为对象传递过去,因为这是每一个订单的具体内容...这个时候我们看上面的数据结构,最外层的是model_list包括的,所以直接取出来,拿到以后呢将我们需要的data拿到,转为json格式的,这个时候我们下面需要用到里面数据的时候就比较容易拿到,下一步就是怎么将对象...data作为一个参数传递过去,我们需要这样处理一下: JSON.stringify(detalData).replace(/\"/g, "'") 将我们拿到的json对象转为string的字符串,然后用正则表达式将里面所有的
JS函数增强 函数属性 JavaScript中函数也是一个对象,那么对象中就可以有属性和方法,他有一些默认的属性 name 函数名 length 函数参数个数(ES6 ......,因为会随着上层属性变化函数输出内容 函数的输出和输入值以外的信息无关和设备的外部输出也无关 这个函数不能有语义上可观察到的 “副作用” 纯函数辨别案例 slice:slice截取数组时不会对原数组进行任何操作...他是一个特殊函数可以将传入的字符串当作js代码执行 可读性差 有注入风险 必须经过解释器 不会得到引擎的优化 严格模式的使用 js的局限性 : JavaScript 不断向前发展且并未带来任何兼容性问题...; 新旧代码该新模式对于向下兼容有帮助但是也有问题出现 就是创造者对于js的不完善之处会一直保留 ES5标准中提出了严格模式的概念,以更加严格的方式对代码进行检测和执行 只需要在代码的开头或者函数的开头...加入use strict就可以开启严格模式 JS对象增强 数据属性描述符 我们的属性一般定义在对象的内部或者直接添加到对象内部,但是这种方式我们就不能对属性进行一些限制,比如这个属性是否是可以通过delete
天生我才必有用 // 1.将js...对象转换成jQuery对象 // 步骤: // a....获取js对象 >>也就是DOM对象 var oH = document.getElementsByClassName("h1"); // b....// 2.将jQuery对象转换成js对象 // 第一种方法: alert($('#h2')[0].innerHTML); // 第二种方法:
箭头函数中没有 arguments 1. arguments 介绍 众所周知,js 是一门非常灵活的语言。...当我们在 js 中调用一个函数时,经常会给函数传递一些参数,js 把调用函数时传入的全部实参存储到一个叫做 arguments 的类数组对象里面 arguments 是一个类数组对象,不是一个真正的数组...它类似数组,除了 length 属性和通过索引获取元素之外没有任何数组属性。...这里做下总结 arguments 是类数组对象(伪数组),即不是一个真正的数组,而是一个对象。...defined const arrow = () => { console.log(arguments);}arrow('html', 'css', 'js') 箭头函数中虽然没有 arguments
函数 JavaScript 函数通过 function 关键词进行定义,其后是函数名和括号 ()。 函数名可包含字母、数字、下划线和美元符号(规则与变量名相同)。...不使用 () 访问函数将返回函数声明而不是函数结果。name 引用的是函数对象,而 name() 引用的是函数结果。可以将函数对象赋值给变量(变量的值是函数定义)。...对象 JavaScript 对象也是变量,但是对象包含很多值。JavaScript 对象是被命名值的容器。 值以名称:值对的方式来书写(名称和值由冒号分隔),名称:值对被称为属性。...对象也可以有方法,方法是在对象上执行的动作。方法以函数定义被存储在属性中。方法实际上是以属性值的形式存储的函数定义。...可以以两种方式访问对象属性: objectName.propertyName objectName["propertyName"] 3.
document.write("用age进行排序,获得的最后一个元素的name是:【"+data[2].name+"】") 29 说明:createCompareFun()函数内部...,嵌套一个内部函数,函数作为值被return返回, 内部函数传两个参数,并通过[]讲createCompareFun()函数的propertyName属性解析出来,在通过常规比较函数进行判断、比较。...在data中,定义了一个有三个元素的对象数组,最后调用createCompareFun()函数,并根据自己需要比较的属性来传参,函数对数组进行排序。得到比较的结果。...再加一个普通的比较函数 1 function compare(value1,value2){ 2 if(value1>value2
但在js中不存在类的概念,js不是基于类,而是通过构造函数(constructor)和原型链(propotype chains)实现的。...: 所有的实例对象都可以继承构造器函数中的属性和方法。...所以,缺点就是:同一个构造函数的对象实例之间无法共享属性和方法。 为了解决构造函数的这个缺点,js提供了prototype属相来解决该问题。 ...propotype属性的作用 js中每个数据类型都是对象,除了null 和 undefined,而每个对象都是继承自一个原型对象,只有null除外,它没有自己的原型对象,最终的Object的原型为null...3.了解了构造器,我们来看下原型prototype JS中万物都是对象,但是对象也分为:普通对象和函数对象,也就是Object 和 Function. 那么怎么区分普通对象和函数对象呢?
目录 jQuery的概念 jQuery快速入门 1、下载jQuery 2、导入JQuery的js文件 3、jQuery的使用 jQuery对象和JS对象区别与转换 jQuery转为js js转为jQuery...在了解jQuery对象和JS对象之间的区别和转换前,我们先对jQuery框架进行一个简单的入门。...JS对象区别与转换 相比于JS对象,jQuery对象在操作时更加方便,代码更加简洁 但是需要注意的是:jQuery对象和JS对象的方法是不通用的,那么我们如果想在jQuery中使用js方法,或在js中使用...因此,在这里和大家分享一下jQuery对象和JS对象之间的相互转换 jQuery转为js 使用jQuery对象[索引] 或者 jQuery对象.get(索引)将jQuery对象转化为js对象,即可使用...divs2.get(1).innerHTML = "eee" //将jQuery对象对象转化为js 好了,关于jQuery对象和JS
js匿名函数和立即执行函数 1. 匿名函数 a)写法 b) 特点 2. 立即执行函数 a) 写法 b) 特点 c) 示例 1. 匿名函数 匿名函数又叫拉姆达函数, 使用前需要先赋值。...var hello=function(){ console.log("hello"); }; hello();//hello b) 特点 匿名函数可以直接访问到外层署名函数(Foo)中的变量...(使用关键字var定义的),但不能访问外层署名函数的属性(使用关键字this定义的) 匿名函数既可以直接访问外层匿名函数中的变量,也可以直接访问外层匿名函数中的属性 外层函数类型: 署名函数 匿名函数...立即执行函数 该类函数没有声明,直接执行,执行完立即释放。一般做初始化比较合适。...; b) 特点 只有表达式才能被执行,如function (){}(),这样不行,因为function (){}是声明不是表达式,如果是var fn=function (){}();就可以 但执行后,函数名或者变量就不代表函数了
本章节复习的是JS中的Map和Set对象,是个集合。 前置知识: Map和Set对象是在ES6中被引入的,作为一种由 key值标记的数据容器。...Map和Set对象承载的数据元素可以按照插入时的顺序,被迭代遍历。 1 Set对象 介绍: Set数据结构类似数组,但所有成员的值唯一。...Set本身为一个构造函数,用来生成 Set数据结构,使用 add方法来添加新成员。...[...new Set([5,'5'])]; // [5, "5"] 属性和方法: 属性: Set.prototype.constructor:构造函数,默认就是 Set函数。...forEach():使用回调函数遍历每个成员。 Set遍历顺序是插入顺序,当保存多个回调函数,只需按照顺序调用。
1.对象转数组 var obj = {name:”张三”,name:”李四”,name:”王五”}; var arr = []; arr = Object.values(obj) //obj就被转换成数组了...2.数组转对象 var obj={}; var arr = []; for(key in arr) { obj[key] = arr[key] //上面的对象obj会被这里新转换的替换 } 3.获取对象长度...对象的长度不能用.length获取,用js原生的Object.keys可以获取到 var obj = {‘ww’:’11’,’ee’:’22}; var arr = Object.keys
领取专属 10元无门槛券
手把手带您无忧上云