首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Fabric.js 元素选中状态的事件与样式

    ---- 本文简介 你是否在使用 Fabric.js 时希望能在选中元素后自定义元素样式或选框(控制角和辅助线)的样式? 如果是的话,可以放心往下读。...本文要介绍 Fabric.js 的背景色有2种。一种是元素自身的背景色,另一种是选中后的背景色。 在 Fabric.js 里,背景色和填充色是两回事。...getActiveObject() 和 getActiveObjects() 从名字来看就已经知道,末尾没加 s 的就是返回当前选中的元素;末尾加了 s 的就是返回当前选中的所有元素(比如通过框选操作选择了一堆元素...代码仓库 ⭐ Fabric.js 元素选中状态的事件与样式 推荐阅读 我最近在整理 Fabric.js 常用方法,有兴趣的可以看看 《Fabric.js中文教程》 《Fabric.js 拖放元素进画布》...《Fabric.js 限制边框宽度缩放》 《Fabric.js 监听元素相交(重叠)》 《Fabric.js 橡皮擦的用法(包含恢复功能)》 《Fabric.js 喷雾笔刷 从入门到放肆》 《Fabric.js

    7.2K20

    Js - JQ事件委托( 适用于给动态生成的脚本元素添加事件

    研发加了ajax事件后,我的交互效果有部分受了影响! 一个小姑娘,在一群大老爷们研发堆里,对着昏暗的电脑和看不太懂的后台代码,改了半天。最后没解决。我就回来了。...所以一开始事件找不到“接头人”就没有执行。 扫噶,定位到问题,就好解决了。 之所以整理成随笔,是因为我之前没遇到过这个问题,听过事件委托机制,但是根本没研究过不知道适用于什么样的bug场景。...,是通过获取元素的类名被点击后执行对应方法,但是研发套完模板,他会把所有的结构先清空,导致jq根本找不到那个元素,所以事件就不得执行了。...正规点的说:JS异步加载,JQ事件不被执行解决方法(百度的标题,hah) jquery中动态新增的元素节点无法触发事件问题(同上) 解决方法: ? ?...但是缺点是:给一个元素添加多个事件委托机制时,他就挂了。  王者方法:on ? //模拟多个事件!

    4.9K50

    js动画事件_JavaScript事件

    js之动画事件 首先,动画事件主要包括以下三个animationstart,animationiteration和animationend事件,下面做简单分别介绍。...animationstart 该事件在css动画开始播放时触发 animationiteration 该事件在css动画重新播放时触发 animationend 该事件在css动画结束播放时触发 我们知道...animation:name duration timing-function delay iteration-count direction; 分别是:动画名称 动画持续事件 动画运行速度曲线 动画开始时的运行时间...this.innerHTML="动画重新运行"; x.style.background="greenyellow"; } function myanimationend() //动画运行结束时触发,同样也是通过事件监听事件...本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

    18.4K10

    Js 事件委托(事件代理)

    一、概述 事件委托,又叫事件代理。事件委托就是利用事件冒泡,只指定一个事件处理程序,就可以管理某一类型的所有事件。 例子:有三个同事预计会在周一收到快递。...二、为什么是使用事件委托 一般来说,dom需要有事件处理程序,我们都会直接给它设事件处理程序就好了,那如果是很多的dom需要添加事件处理呢?...比如我们有100个li,每个li都有相同的click点击事件,可能我们会用for循环的方法,来遍历所有的li,然后给它们添加事件,那这么做会存在什么影响呢?...,这就是为什么性能优化的主要思想之一就是减少DOM操作的原因;如果要用事件委托,就会将所有的操作放到js程序里面,与dom的操作就只需要交互一次,这样就能大大的减少与dom的交互次数,提高性能; 每个函数都是一个对象...三、事件委托原理 事件委托利用的是事件冒泡原理,将事件绑定到父级元素上,当点击子元素时,通过事件冒泡将事件传递到父级元素。  四、总结: 那什么样的事件可以用事件委托,什么样的事件不可以用呢?

    11.4K30

    input元素的oninput事件和onchange事件

    input元素的oninput事件和onchange事件 框架用多了,感觉原生的有点弱化了,不说了,是时候巩固一波了 ^ _ ^ 1、input元素上绑定事件的三种方式: 第一种:直接在元素标签上添加oninput...) { // 处理事件代码 } 第二种:获取input元素,然后在元素对象上添加oninput属性,属性值为函数,函数内部为处理事件函数的调用 <input type="text" id="...} 第三种:获取input<em>元素</em>,然后在<em>元素</em>上利用<em>事件</em>监听添加input<em>事件</em> var inputEle = document.querySelector...2、input<em>元素</em>的oninput<em>事件</em>和onchange<em>事件</em>的区别 oninput<em>事件</em>是在输入框中输入时就会触发 onchange<em>事件</em>是在输入框输入完内容后,输入框失焦后触发 onchange<em>事件</em>兼容性好...,主流浏览器都支持 oninput<em>事件</em>IE9以下不支持,其余主流浏览器都支持,针对IE9以下的可以使用onpropertychange<em>事件</em>来替代 参考文献: [1] oninput <em>事件</em> [2] input

    3.3K10

    riot.js教程【五】标签嵌套、命名元素事件、标签条件

    前文回顾 riot.js教程【四】Mixins、HTML内嵌表达式 riot.js教程【三】访问DOM元素、使用jquery、mount输入参数、riotjs标签的生命周期; riot.js教程【二...yield占位符输出的,其实是text变量 这就是在标签内嵌入HTML代码 命名元素元素具备ref属性的时候, 这个元素会被链接到this.refs上, 这样你就可以很方便的用JS访问到它 <login...,所以你可以在mount事件中访问到this.refs 事件 DOM事件可以直接和riotjs标签内的方法绑定,示例如下: ...,那么方法执行完之后,就不会执行this.update()事件; 方法的第一个参数就是标准的event对象 e.currentTarget 指代触发事件的DOM元素 e.target 也指代触发事件的DOM...,是false的时候,不会把标签加入到dom元素

    3.9K80

    前端day12-JS(WebApi)学习笔记(操作元素属性,事件介绍)

    JavaScript 能够改变页面中的所有 HTML 元素 JavaScript 能够改变页面中的所有 HTML 属性 JavaScript 能够改变页面中的所有 CSS 样式 JavaScript 能够对页面中的所有事件做出反应...可以获取满足选择器条件的 所有元素 b....5.jpg 3.1-元素属性操作 1.语法:元素.属性名(其实就是对象的取值赋值语法) 设置元素属性的值:元素.属性名 = 属性值 2.特点: 1.class在js中是一个关键字,如果要拿到类名需要使用...7.jpg 3.3-表单元素常用属性 8.jpg 3.4-元素属性操作注意点 9.jpg 4-事件介绍及注册事件 1.事件js处理用户交互的一种机制 交互:什么元素在什么时刻做什么事 2.事件的三要素...:组成事件的三要素 事件源:什么元素(div p) 事件类型:什么时刻(鼠标点击onclick 鼠标移入:onmouseover) 事件处理函数:做什么事(一段代码:函数) 3.注册事件:本质是给元素属性赋值

    1.6K00

    事件基础及操作元素

    事件三要素 事件源(谁):触发事件元素 事件类型(什么事件): 例如 click 点击事件 事件处理程序(做啥):事件触发后要执行的代码(函数形式),事件处理函数 案例代码 <body...常见的鼠标事件 ? 2. 操作元素 JavaScript的 DOM 操作可以改变网页内容、结构和样式,我们可以利用 DOM 操作元素来改变元素里面的内容、属性等。...样式属性操作 我们可以通过 JS 修改元素的大小、颜色、位置等样式。 常用方式 ? 方式1:通过操作style属性 元素对象的style属性也是一个对象!...获取元素 所有的小li        var lis = document.querySelectorAll('li');        for (var i = 0; i < lis.length....className = 值; 因为class是关键字,所有使用className。

    1.4K20

    js事件大全

    onBlur IE3|N2|O3 当前元素失去焦点时触发的事件 [鼠标与键盘的触发均可] onChange IE3|N2|O3 当前元素失去焦点并且元素的内容发生改变而触发的事件 [鼠标与键盘的触发均可...] onFocus IE3|N2|O3 当某个元素获得焦点时触发的事件 onReset IE4|N3|O3 当表单中RESET的属性被激发时触发的事件 onSubmit IE3|N2|O3 一个表单被递交时触发的事件...元素完成需要显示的内容后触发的事件 onStart IE4|N|O 当Marquee元素开始显示内容时触发的事件 编辑事件 事件 浏览器支持 描述 onBeforeCopy IE5|N|O 当页面当前的被选择内容将要复制到浏览者系统的剪贴板前触发的事件...onBeforeCut IE5|N|O 当页面中的一部分或者全部的内容将被移离当前页面[剪贴]并移动到浏览者的系统剪贴板时触发的事件 onBeforeEditFocus IE5|N|O 当前元素将要进入编辑状态...onLoseCapture IE5|N|O 当元素失去鼠标移动所形成的选择焦点时触发的事件 onPaste IE5|N|O 当内容被粘贴时触发的事件 onSelect IE4|N|O 当文本内容被选择时的事件

    3.8K10

    JS 事件循环

    ,脚本执行,事件处理等 其包含的线程有:GUI 渲染线程(负责渲染页面,解析 HTML,CSS 构成 DOM 树)、JS 引擎线程、事件触发线程、定时器触发线程、http 请求线程等主要线程 关于执行中的线程...: 主线程:也就是 js 引擎执行的线程,这个线程只有一个,页面渲染、函数处理都在这个主线程上执行。...工作线程:也称幕后线程,这个线程可能存在于浏览器或js引擎内,与主线程是分开的,处理文件读取、网络请求等异步事件。...上述过程的不断重复就是我们说的 Event Loop (事件循环)。...宏任务主要包含:script( 整体代码)、setTimeout、setInterval、I/O、UI 交互事件、setImmediate(Node.js 环境) 微任务主要包含:Promise、MutaionObserver

    15.4K10

    js --- 事件

    1.事件流   事件发生时会在元素节点与根节点之间按照特定的顺序传播,路径所经过的所有节点都会收到该事件,这个传播过程即DOM事件流。...2.两种事件流模型   1.冒泡型事件流:事件的传播是从最特定的事件目标到最不特定的事件目标。即从DOM树的叶子到根   2.捕获型事件流:事件的传播是从最不特定的事件目标到最特定的事件目标。...即从DOM树的根到叶子 3.绑定事件的方法   1.普通浏览器 绑定事件:addEventListener(type,name,bool);     删除事件:removeEventListener...()   2.ie 低版本 绑定事件:attachEvent()     删除事件:detachEvent() 4.参数说明 type 事件类型 例如:click load   name...事件执行函数   bool true 为事件捕获 && false 为事件冒泡 5.阻止事件冒泡和 事件捕获 1.阻止事件冒泡 不 阻止默认行为     event.stopPropagation

    7.6K30

    js事件循环

    首先,我们来解释下事件循环是个什么东西: 就我们所知,浏览器的js是单线程的,也就是说,在同一时刻,最多也只有一个代码段在执行,可是浏览器又能很好的处理异步请求,那么到底是为什么呢?...我们先来看一张图(这张图来自于http://www.zcfy.cc/article/node-js-at-scale-understanding-the-node-js-event-loop-risingstack...从上图我们可以看出,js主线程它是有一个执行栈的,所有js代码都会在执行栈里运行。...而当主线程执行完栈中的所有代码后,它就会检查任务队列是否有任务要执行,如果有任务要执行的话,那么就将该任务放到执行栈中执行。如果当前任务队列为空的话,它就会一直循环等待任务到来。...原因:因为一开始js主线程中跑的任务就是macrotask任务,而根据事件循环的流程,一次事件循环只会执行一个macrotask任务,因此,执行完主线程的代码后,它就去从microtask队列里取队首任务来执行

    18.8K41
    领券