文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

JS轻量编辑器怎么使用

2023-07-04 10:23

关注

本文小编为大家详细介绍“JS轻量编辑器怎么使用”,内容详细,步骤清晰,细节处理妥当,希望这篇“JS轻量编辑器怎么使用”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。

一款纯 JS 实现的轻量化图片编辑器

如果上面的场景是你所遇见的, 也想轻量快速的处理一些图片, 这个项目就是为你而准备的

JS轻量编辑器怎么使用

Optimizer 框架特点

JS轻量编辑器怎么使用

启动

首先需要场景管理器, 通过继承 GenScene 来创建场景, 场景里对于页面中的多个控制器进行管理

class MainScene extends GenScene {    constructor(optimizer) {        super(optimizer)    }}

全局使用 instance 获取实例, 加载场景管理器, 最简单的 Optimizer 程序就启动了

GenOptimizer.instance(function(o){    let scene = MainScene.new(o)    o.runWithScene(scene)})

场景管理器 (Scene)

事件 (Event)

页面事件

...<div class='gen-auto-button-area'>    <button class='gen-auto-button' data-value='config.arg1'>text</button></div>...// 注册页面 class, 全局可用this.registerPageClass({    "buttonArea": 'gen-auto-button-area',    ...})// 注册全局事件       this.registerGlobalEvents([         {        eventName: "click",        // 事件绑定的元素区域        className: sc.pageClass.buttonArea,        // 在 所有 configToEvents 响应之 前 触发        after: function(bindVar, target) {            // bindVar: 绑定的变量            // target: 事件触发的目标        },                // 在 所有 configToEvents 响应之 后 触发        before: function(bindVar, target) {            // bindVar: 绑定的变量            // target: 事件触发的目标        },        // 事件响应        configToEvents: {            // 自定义绑定的变量: 事件触发后的响应            "config.arg1": function(target) {                            },            "action.arg1": function(target) {                            },            ...        }    },    ...])

鼠标事件

this.resgisterMouse(function(event, action) {     // event 是鼠标点击的事件    // action 为鼠标点击的事件名称        if (action == 'mouseleave') {        console.log('mouseleave canvas')    } else if (action == 'up') {        console.log('up canvas')    } else if (action == 'down') {        console.log('down canvas')    } else if (action == 'move') {        console.log('move canvas')    }})

键盘事件

this.registerAction("Backspace", status => {    // status 为 'down' 时, 表示按下, 为 'up' 时, 表示松开    console.log("Backspace", status)})this.registerAction("s", status => {    // status 为 'down' 时, 表示按下, 为 'up' 时, 表示松开    console.log("s", status)})

组件 (Component)

注册组件

class MyComponent extends GenComponent {    constructor(control) {        super(control.scene)        this.control = control    }    ...}this.bindComponent('attribute', MyComponent.new(this))

使用组件

// 全局可使用组件let data = ...this.getComponent('attribute').buildWith(data

读到这里,这篇“JS轻量编辑器怎么使用”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注编程网行业资讯频道。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯