function once(fn) { let flag = false; let result = null; return function (...args) {...flag = true; result = fn.call(this, ...args); return result; }; } let onceFn1 = once...onceFn1(1, 2)); // 3 console.log(onceFn1(3, 2)); // 3 console.log(onceFn1(3, 3)); // 3 let onceFn2 = once
做笔记,以防自己忘记~~ JS获取事件event,不同浏览器有不同的做法。 例如IE下,在js函数中,通过window.event就可以获取,不必在函数中添加什么参数。...也可以用Prototype或者JQuery等,它们有他们对事件的包装。还是使用JS库比较好,不然就有下边的麻烦。...同时注意event的 兼容性问题。 感觉这个挺好,可以捕获当前事件作用的对象,如event.srcElement.tagName可以捕获活动标记名称。...在 ie中处理事件直接使用window.event对象即可,但在firefox中,是没有 window.event对象的,函数需要使用事件的时候,需要在事件发生时把事件作为参数传递给函数,不象在ie...中,事件对象是全局的,随处都可以访 问.下面这个getEvent()函数可以兼容firefox和ie,只需要在访问事件对象的函数的开始调用getEvent()即可,不用再把事件作为 参数传递.以下代码已经实验通过
="X-UA-Compatible" content="ie=edge"> <script type="text/javascript" src='vue.min.<em>js</em>...function(event,l) { console.log(event,l); } } }); 解释: $event是<em>事件</em><em>对象</em>...="X-UA-Compatible" content="ie=edge"> <script type="text/javascript" src='vue.min.js...一样的效果,都是事件冒泡. 效果: ? ? <!...都是阻止默认事件. 效果图: ?
2.事件的三种写法 //在HTML中把事件处理函数作为属性执行JS函数 ...当触发某个事件时,会产生一个事件对象,这个对象包含着所有与事件有关的信息。...在非IE浏览器下,事件对象作为事件的参数,在IE下是window.event //实现跨浏览器兼容获取event对象 input.onclick = function (evt) {...比如我们有100个li,每个li都有相同 的click点击事件,可能我们会用for循环的方法,来遍历所有的li,然后给它们添 加事件,那这么做会存在什么影响呢?...,这就是为什 么性能优化的主要思想之一就是减少DOM操作的原因;如果要用事件委托,就 会将所有的操作放到js程序里面,与dom的操作就只需要交互一次,这样就能大 大的减少与dom的交互次数,提高性能;
方法 add(object) 添加 insertAt(object,index) 添加 remove(object) 移除 forEachObject 循环遍历 getObjects() 获取所有对象...getSelectionElement()获取选中的元素 getActiveObject() 获取选中的对象 getActiveObjects() 获取选中的多个对象 discardActiveObject...()取消当前选中对象 isType() 图片的类型 setColor(color) = canvas.set("full",""); rotate() 设置旋转角度 setCoords() 设置坐标...事件 object:added object:removed object:modified object:rotating object:scaling object:moving object:selected...freeDrawingBrush.width 自由绘笔触宽度 canvas.setZoom(2); 设置画板缩放比例 IText的方法 selectAll() 选择全部 getSelectedText
大家好,又见面了,我是你们的朋友全栈君 法一:使用for…in…循环 var obj = { '0':'a', '1':'b', '2':'c'}; for(let i in obj){
1 event.target代表当前触发事件的元素,可以通过当前元素对象的一系列属性来判断是不是我们想要的元素 2 target属性可以是注册事件时的元素或者子元素,通常用于比较event.target...和this来确定是不是由于冒泡而触发的,经常用于事件冒泡时处理事件委托 3 事件对象是用来记录一些事件发生时的相关信息的对象。...事件对象只有事件发生时才会产生,并且只能是事件处理函数内部访问,在所有事件处理函数运行结束后,事件对象就被销毁 4 jQuery事件对象的作用 li都有一个共同的父元素,而且所有的事件都是一致的...,如果点击一个链接(a标签),浏览器不会跳转到新的 URL 去,可以用 event.isDefaultPrevented() 来确定这个方法是否(在那个事件对象上)被调用过了 8 event.stopPropagation...this是可以变化的,但event.target不会变化,它永远是直接接受事件的目标DOM元素 13 .this和event.target都是dom对象,使用jquey中的方法可以将他们转换为
; 它不会拷贝对象的不可枚举的属性; 不可以拷贝对象中的对象; 可以拷贝 Symbol 类型的属性; 无法正确拷贝属性和属性 可以拷贝undefined/boolean/null/function/Date...,浅拷贝 不是深拷贝,循环引用、各种数据类型都可以拷贝,引用类型不是深拷贝 JSON.parse(JSON.stringfiy()),不完全深拷贝 拷贝的对象的值中如果有函数、undefined、symbol...这几种类型,经过 JSON.stringify 序列化之后的字符串中这个键值对会消失; 拷贝 Date 引用类型会变成字符串; 无法拷贝不可枚举的属性; 无法拷贝对象的原型链; 拷贝 RegExp 引用类型会变成空对象...; 对象中含有 NaN、Infinity 以及 -Infinity,JSON 序列化的结果会变成 null; 无法拷贝对象的循环引用,如果对象中有循环引用,会报错: Uncaught TypeError...JavaScript内置对象的复制: Set、Map、Date、RegExp等 * 2.
// 判断对象的方法 let obj6 = { a: 1, b: 2 }; // 1. typeof console.log(typeof obj6 === "object"); // 2. instanceof...__proto__===Object.prototype); 以上方法中 1,2 都是不准确的饿,推荐方法 4.
可以使用定义变量的方法 obj[ obj[1] ]
总结几个不太熟练的js对象方法。...方法是以sourceObj为targetObj的原型对象创建一个新的空对象,我用这个来验证sourceObj是不是targetObj的原型对象,结果为true Object.defineProperty...User.prototype === Object.getPrototypeOf(u)); // true Object.setPrototypeOf() Object.setPrototypeOf() 静态方法可以将一个指定对象的原型...冻结对象可以防止扩展,并使现有的属性不可写入和不可配置。被冻结的对象不能再被更改:不能添加新的属性,不能移除现有的属性,不能更改它们的可枚举性、可配置性、可写性或值,对象的原型也不能被重新指定。...freeze() 返回与传入的对象相同的对象。 冻结一个对象是 JavaScript 提供的最高完整性级别保护措施。
我个人的理解是: 全名函数是直接在input标签(也就是HTML中)触发的事件;而匿名函数是在js中触发的事件。...三、js对象 学一学js中内置的几种常用对象 1数组对象 ? ①关于数组遍历 在Java中数组直接打印是一串地址,但是在js中数组是可以直接打印的,数字之间用逗号隔开。...而其它方法对数组本身没有影响,只是形成了一个新的数组。 2日期对象 ? ①日期对象 直接打印是一串英文格式的日期。 ②getTime() 也和Java中一样,获取系统当前时间的毫秒值。...③toLocaleString() 将时间格式转换成当前系统对应的本地格式。 在Java中,需要自定义格式,显得特别的麻烦,但是在js中直接调用该方法就可以了。 3全局对象 什么叫全局对象呢?...就是不用创建对象,直接可以使用该对象。 有点类似于Java中的静态方法,但是js中更简洁,连类名都没有的。 ?
// 对象里的方法写的是箭头函数,this始终访问全局 var name = "xiaoming"; var obj1...let getName11 = obj1.getName.bind(obj1); getName11(); // xiaoming // 对象的方法写的...function 声明,直接调用 this 指向对象本身,将调用的方法单独保存起来调用,this 指向全局,通过bind 改写 this 指向后,可以继续指向 对象本身 var
数组使用fliter 函数是可以过滤掉的,但是对象的属性怎么过滤呢? 剔除少数属性,要多数属性 有时候需要剔除少数属性,留下大多数。...类似于TS的omit 例子: let person = { name:"jack chen", age:54, address:'hongkong' } let {name,...xiaohong...类似于TS的pick 例子: let person = { name: "jack chen", age: 54, address: "hongkong", }; let namePerson
本期介绍 本期主要介绍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 对象是什么?有什么作用?..., 通过操作对象的属性或者方法,来达到操作或者改变 HTML 展示效果的目的。...加载到浏览器的内存 加载并解析到内存中,会生成一张 DOM 树 其中: 在 DOM 树中所有的成员都可以成为节点 (Node) 整个 DOM 树,是一个文档节点对象,即...JS 事件总结 常见事件 示例代码: 鼠标键盘事件 示例代码: 3. 全局函数(global) 3.1 执行 作用:用于增强程序的扩展性。
---在JavaScript中,有几种常用的方法可以用来遍历对象:for...in循环使用for...in循环可以遍历一个对象中的所有可枚举属性。它会将属性名逐个赋值给循环变量,并执行循环体内的代码。...如果只想遍历对象自身的属性,可以通过hasOwnProperty()方法来判断属性是否为对象自身的属性。...对象的属性在内部存储时是没有固定顺序的,因此遍历顺序不一定与属性定义的顺序相同。...Object.keys()和Object.getOwnPropertyNames()方法只会返回对象自身的属性(包括可枚举和不可枚举属性),而不会返回继承的属性。...你可以选择其中一种方法根据需要遍历对象的属性。Object.keys()方法结合forEach()循环Object.keys(obj)会返回一个包含对象自身可枚举属性的数组。
在触发DOM上的某个事件时,会产生一个事件对象event,这个对象中包含这所有与事件有关的信息。包括导致事件的元素、事件的类型和事件的相关信息。例如鼠标操作的事件中,会包含鼠标的位置信息。...event的属性以及方法,在事件处理程序内部,对象this始终等于currentTarget的值,而target则包含事件的实际目标。...document.body.onclick发生在事件的冒泡阶段。 IE中的事件对象 在IE中方式event对象可以通过多种方式,取决于指定事件处理程序的方法。...但是如果通过attachEvent添加事件,则事件处理程序会传递一个event对象。 IE的event对象同样包含创建它的相关属性和方法,与DOM事件一样,也会因为事件类型的不同而不同。... 虽然DOM与IE的event对象不同,但是可以通过js库,来解决浏览器的兼容性。
简介 JS中经常需要对对象的属性进行遍历,下面我们来总结一下JS遍历对象属性的几种方法。...Object.keys() Object.keys()方法接收一个对象为参数,返回一个数组,包含该对象自身的(不含继承的)可枚举属性的key值(不含Symbol属性)。...Object.values() Object.values()方法接收一个对象为参数,返回一个数组,包含该对象自身的(不含继承的)可枚举属性得value值(不含Symbol属性)。...参考 如何遍历JS对象中所有的属性 包括enumerable=false的属性?...javaScript遍历对象、数组总结 【探秘ES6】系列专栏(八):JS的第七种基本类型Symbols MDN-Object
学习zepto.js(对象方法)[4] 今天说说那一套获取元素集合的一些方法: ["children", "clone", "closest", "contents", "empty...上边那个过滤方法用的地方比较多,所以给它放在上边; children方法调用的filtered传入的是两个参数,第一个是一个集合,将所有对象的所有的子节点取出,并放入一个集合;children方法内部调用的...我们调用的是对象方法,而对象方法调用的那个就是一个普通的内部私有函数- -(望理解它们之间的区别); 返回的是做一个兼容处理的获取子元素的实现,如果节点存在children属性就直接取出,不存在的话,就循环...如果不是一个字符串,就判断是否是一个类数组,并且对象的item是一个方法,(是的,变相的判断为一个zepto对象.) 其余的情况,直接通过参数构建一个zepto对象....也就是说,not方法传入的参数类型是可以比filter更丰富一些的. 可以传入一个zepto对象,或者一个dom标签数组.一个html片段.等等…… 当然最后返回的对象决不会存在于not的参数中.
大家好,又见面了,我是你们的朋友全栈君 用 entries方法 和 map 方法,对象转成数组 let Obj = { allOrder: 1, notStart: 2,...如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
领取专属 10元无门槛券
手把手带您无忧上云