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

    Fabric.js 清空画布,甚至连画布元素也给你干掉😏

    本文主要聊聊: 在 fabric.js 中如何清空画布; 和原生 canvas 对比,fabric.js 到底有多方便; 销毁 fabrci.js 创建的画布; 把 canvas 元素也销毁掉; 原生...在原生 Canvas 中要清空画布,需要使用获取画布的宽高。...就算你没了解过 fabric.js 也应该能猜出个大概。 上面的例子中,当点击按钮时就调用 canvas.clear() 直接清空了画布。在这个过程中你根本不需要了解画布的宽高。...} 从上面的例子中可以看到,在销毁画布的时候,canvas 元素也获得了自由(没被 fabric.js 劫持了)。...将 Canvas 元素也干掉:借助 getElement 如果想在销毁画布后,将 canvas 元素也移除掉,可以借助 getElement 获取当前画布元素,然后使用 dispose 销毁 fabric

    4.5K20

    JavaScript移除对象中不必要的属性

    业务开发中,我们经常会遇到:基于后端返回接口数据,前端保存到对象 Object 中,前端开发过程中为了一些场景的便利性,需要在该对象中增加相应的属性,但这些属性对于后端没有意义,保存提交时希望删除掉。...Reflect.deleteProperty(person, 'email') 方式二:解构 形成新的对象,避免在引用原始对象的地方产生副作用。...总结 实际使用中,强烈建议方式二来操作,不要影响原数据。...特别是在mvvm框架中,原数据往往是响应式的,delete/deleteProperty 意味着切断“响应关系”,delete 操作之后的数据响应就会有问题。...$set(this.person, 'address', 'xxx') } } 执行 delete 操作,js 对象属性剔除掉了,但页面没有及时响应,可以使用 vue 中的 this.

    2.2K30

    Fabric.js 居中元素 🎗️

    阅读本文需要你有一定的 Fabric.js 基础,如果还不太了解 Fabric.js 是什么,可以阅读 《Fabric.js 从入门到膨胀》 创建基础项目 为了方便演示,我在初始化画布的时: 添加一个背景图...添加一个矩形,之后要居中的对象就是它了。 添加鼠标滚轮滚动时缩放画布(方便演示 基于视窗 和 基于画布 的区别)。 添加鼠标拖拽画布平移位置(方便演示 基于视窗 和 基于画布 的区别)。...// 宽度 60px height: 60, // 高度 60px originX: 'center', originY: 'center' }) // 将矩形添加到画布中...,方法1是用画布操作指定的对象;方法2是元素自己根据视窗来调整自己的位置。...带动画效 // 省略部分代码 canvas.fxCenterObjectH(rect) 复制代码 带动画的效果需要在画布中调用 fxCenterObjectH 方法。

    3.7K20

    JavaScript移除对象中不必要的属性

    业务开发中,我们经常会遇到:基于后端返回接口数据,前端保存到对象 Object 中,前端开发过程中为了一些场景的便利性,需要在该对象中增加相应的属性,但这些属性对于后端没有意义,保存提交时希望删除掉。...Reflect.deleteProperty(person, 'email') 方式二:解构 形成新的对象,避免在引用原始对象的地方产生副作用。...总结 实际使用中,强烈建议方式二来操作,不要影响原数据。...特别是在mvvm框架中,原数据往往是响应式的,delete/deleteProperty 意味着切断“响应关系”,delete 操作之后的数据响应就会有问题。...$set(this.person, 'address', 'xxx') } } 执行 delete 操作,js 对象属性剔除掉了,但页面没有及时响应,可以使用 vue 中的 this.

    1.8K10

    Fabric.js 让用户手动加粗文本

    本文简介 点赞 + 关注 + 收藏 = 学会了 本文介绍 Fabric.js 的 IText 在画布上如何让用户手动加粗文本。...} } 加粗选中的文字 可以用 setSelectionStyles 设置被选中的文字样式,里面传一个样式对象即可。...,本文介绍3种方法设置画布宽高,让你的画布更容易适配不同的使用场景 《Fabric.js 更换图片的3种方法(包括更换分组内的图片,以及存在缓存的情况)》 如果你的项目需要动态更换画布上的图片,那我也给你总结了...3中方法 《Fabric.js 摆正元素的4种方法(带过渡动画)》 一键摆正被你旋转过的元素 《Fabric.js 将本地图像上传到画布背景》 除了在初始化时设置画布背景外,我还做了本地上传背景的功能,...让画布在运行时也能修改背景图 《在 Vue3中使用Fabric.js实现渐变(Gradient)效果,包括径向渐变radial》 官方入门教程也只有线性渐变,以至于某些文章说 Fabric.js 只支持线性渐变

    3.5K30

    从一个数组中移除重复对象

    在JavaScript项目实践中,我们可能会经常需要移除重复对象的例子,本文通过一个案例来详细解答,并给出了最优解,希望对你有所帮助。...那么,如果我们想从数组中删除这样的重复对象怎么办?令人惊讶的是,这是一个相当难解决的问题。为了了解原因,让我们来看看如何从一个数组中删除重复的对象,如字符串等平面项的数组中删除重复的对象。...如果是,我们就不返回到由filter()方法创建的新数组中。 对象并不像上面这么简单 这个相同的方法对对象不起作用的原因是,任何2个具有相同属性和值的对象实际上并不被认为是相同的。...在比较对象时,不会考虑两个对象的属性和值是否相同的事实。因此,在一个对象数组中的indexOf(object)总是会返回所传递的对象的索引,即使存在另一个属性和值完全相同的对象。...特别是,我做了3件事情 1.只检查数组中的每一个项目和后面的每一个项目,以避免对同一对象进行多次比较 2.只检查未发现与其他物品重复的物品 3.在检查每个属性的值是否相同之前,先检查两个对象是否有相同的键值

    1.9K10

    Fabric.js 拖放元素进画布

    本文简介 学习 Fabric.js,我的建议是看文档不如看 demo。 本文实现的功能:将元素拖进到画布中并生成对应的图形或图片。...解2:Fabric.js 创建元素可看 《Fabric.js 从入门到膨胀》的基础图形篇,要创建图片可以看 图片篇。 解3:缩放画布我在 《Fabric.js 缩放画布》 里讲解过。...解4:移动画布我在 《Fabric.js 拖拽平移画布》 里讲解过。 解5:画布的左上角不一定在body的左上角,也就是鼠标当前位置可能和画布对应的坐标不一样,需要通过加减法计算一下。...这里的坐标是指画布在页面中的位置转换出来的坐标,而且还要计算画布拖拽和缩放过的情况。...我的做法是通过 canvas 元素的 getBoundingClientRect() 方法返回的对象中获取到 top 和 left 两个数据。

    3.3K30

    Fabric.js 橡皮擦的用法(包含恢复功能)

    __canvas = new fabric.Canvas('c') // 在画布中添加图形(本例添加2个正方形) canvas.add( // 第一个正方形(宝蓝色) new...new fabric.EraserBrush 里需要传入画布本身,在初始化画布时的那个对象 const canvas = this....《Fabric.js 自由绘制圆形》 将“框选”动作改造成自由绘制圆形 《Fabric.js 3个api设置画布宽高》 宽高设置并不是在初始化是才能进行的,本文介绍3种方法设置画布宽高,让你的画布更容易适配不同的使用场景...《Fabric.js 更换图片的3种方法(包括更换分组内的图片,以及存在缓存的情况)》 如果你的项目需要动态更换画布上的图片,那我也给你总结了3中方法 《Fabric.js 摆正元素的4种方法(带过渡动画...)》 一键摆正被你旋转过的元素 《Fabric.js 将本地图像上传到画布背景》 除了在初始化时设置画布背景外,我还做了本地上传背景的功能,让画布在运行时也能修改背景图 《在 Vue3中使用Fabric.js

    2.7K30
    领券