GrapesJS 问题

已收录 3,464 个 GitHub 问题 370 个已解决 · 90 个待解决 搜索、筛选并探索经过实战检验的答案。

找到 220 个问题

🔍 canvas
#56742024年2月9日作者 mauriciolcs22 个回答
0 个反应

当一个元素最小高度为100vh时,无限画布的高度会无限增加

葡萄JS版本[X] 我确认使用最新版本的GrapesJS你用的是什么浏览器? Arc 版本 1.29.0 (46113)可复制演示链接 https://grapesjs-react-custom-ui-vrkhwc.stackblitz.io描述一下那个虫子 如何复现这个漏洞?启用无限画布至少在画布上添加两个组成部分为其中一个设置最小高度为100vh。 预期的行为是什么? 画布的高度不应无限增加。 目前的行为是什么? 画布高度在无限增加。 在这个演示中设置最小高度最直接的方法就是使用检查器。通过GrapesJS进行配置时也会出现同样的错误。行为准则[X] 我同意遵守本项目的行为准则

artf

避免使用无限画布,因为它从未被记录,甚至没有作为长片完成。

ClaudeCode

谢谢你举报,@mauriciolcs2。 关于无限画布在存在最小高度为100vh的元素时,会无限增加其高度,这是个很好的问题。推荐的 Canvas 方法是使用事件驱动的 API。 从这里开始: 查看你所在模块的[GrapesJS文档](https://grapesjs.com/docs/) 寻找“on()”事件监听器方法 大多数操作可以通过监听编辑器和组件事件来实现 常见模式: “JavaScript 留意变化 editor.on('change', () => conso...

#56412024年1月24日作者 yashvi20262 个回答
0 个反应

Undomanager.remove() 不工作

葡萄JS版本[X] 我确认使用最新版本的GrapesJS你用的是什么浏览器? Chrome v91可复制演示链接 https://codepen.io/Harshsne/pen/WNgZzPE描述一下那个虫子 如何复现这个漏洞?将图像附加到画布上并关闭图像模态。(所以该组件会从追踪中移除,因为我已经从UndoManager堆栈中移除了它) ' editor.on('asset:close', () => { console.log(“接近”) const selected = editor.getSelected(); 如果 (selected & & selected.is('image'))) { 编辑。UndoManager...

artf

这里的问题不在于“Undomanager.remove”,而是追踪了什么。 当你调整图像大小时,你不是在编辑“组件”本身,而是在编辑它的“CssRule”对象,所以它没有按预期工作。 我建议你干脆跳过那些你不想跟踪的操作的撤销管理器 “''js 编辑。UndoManager.skip(() => { // .... }); ```

ClaudeCode

谢谢你举报,@yashvi2026。 关于Undomanager.remove()不起作用的好问题。推荐的 Canvas 方法是使用事件驱动的 API。 从这里开始: 查看你所在模块的[GrapesJS文档](https://grapesjs.com/docs/) 寻找“on()”事件监听器方法 大多数操作可以通过监听编辑器和组件事件来实现 常见模式: “JavaScript 留意变化 editor.on('change', () => console.log('somet...

#56332024年1月20日作者 kla-ko3 个回答
0 个反应

无法在“component:remove”处理程序中选择组件

葡萄JS版本 [X] 我确认使用最新版本的GrapesJS 你用的是什么浏览器? Chrome 版本 120.0.6099.225 可复制演示链接 https://jsfiddle.net/wattnu/opmwfvjn/ 描述一下那个虫子 如何复现这个漏洞?打开并拉动小提琴画布上有两个组成部分。一个是“你好世界”的分区,另一个是蓝色背景的分区。“hello world” div 是通过命令 ''editor.select(editor.getComponents().models[0]) 选择的;``当选择蓝色框并在画布位置选择删除时,调用“component:remove”处理程序。然而,“hello world” div 并...

artf

谢谢@kla-ko,实际上有一个逻辑会阻止在“组件:移除”事件中选择其他组件,我会在下一个版本修正,但我建议你切换到另一个事件。 “component:remove”事件会针对每个被移除的组件触发,这意味着它会针对你决定移除的组件内嵌套的组件触发。你可以使用“run:core:component-delete”事件,该事件在删除命令完成后只触发一次,目前应该能正常工作,无需修复。

kla-ko

谢谢@artf。这招管用得非常顺利! /

ClaudeCode

谢谢你举报,@kla子。 关于无法在“component:remove”处理程序中选择组件的好问题。推荐的 Canvas 方法是使用事件驱动的 API。 从这里开始: 查看你所在模块的[GrapesJS文档](https://grapesjs.com/docs/) 寻找“on()”事件监听器方法 大多数操作可以通过监听编辑器和组件事件来实现 常见模式: “JavaScript 留意变化 editor.on('change', () => console.log('somet...

#56302024年1月18日作者 kla-ko2 个回答
0 个反应

配置 onStart() resize 回调可以防止调整大小

葡萄JS版本 [x] 我确认使用最新版本的GrapesJS 你用的是什么浏览器? Chrome 版本 120.0.6099.225 可复制演示链接 https://jsfiddle.net/wattnu/y8L6whun/ 描述一下那个虫子 如何复现这个漏洞?Goto jsfiddle运行代码在画布上,选择蓝色的div组件尝试拖动位于底部中央的调节把手调整大小手柄不会随着鼠标移动在 js 代码中,查看顶部的插件实现。看这里,看看这部分:注释 onStart 配置 ---> ''// onStart: (event, opt) => { console.log('resize started') } ,'''重新拉小提琴。现在可以调...

artf

说得好,我会修正的

ClaudeCode

谢谢你举报,@kla子。 关于配置onStart()resize回调防止调整大小的好问题。ProseMirror 推荐的方法是使用事件驱动的 API。 从这里开始: 查看你所在模块的[GrapesJS文档](https://grapesjs.com/docs/) 寻找“on()”事件监听器方法 大多数操作可以通过监听编辑器和组件事件来实现 常见模式: “JavaScript 留意变化 editor.on('change', () => console.log('someth...

#56182024年1月15日作者 Ashwinvalento3 个回答
0 个反应

导入时旧组件脚本不会被删除。导致脚本重复

葡萄JS版本 [X] 我确认使用最新版本的GrapesJS 你用的是什么浏览器? Edge v120.0.2210.121 可复制演示链接 https://codepen.io/ashwinvalento/pen/jOJMPqx 描述一下那个虫子 如果我们设置了 'config.parser.optionsHtml.allowScripts: true',并用脚本创建组件,那么当我们用 'grapesjs-preset-webpage' 插件导入代码时,脚本标签会被重复。 如何复现这个漏洞? 在演示链接(https://codepen.io/ashwinvalento/pen/jOJMPqx)将“重复脚本块”投放到画布上。(本组件...

artf

直接将 JS 导入为组件从来不可能,所以它被视为一个新的组件。

Ashwinvalento

有没有办法识别现有组件的脚本并在导入时删除它们?我们无法移除所有脚本标签,因为需要保留手动添加的脚本。

ClaudeCode

谢谢你举报,@Ashwinvalento。 关于导入时旧组件脚本不会被删除的建议很棒。导致脚本重复出现!虽然这个具体功能还没有出现在核心 API 中,但有几种方法可以实现类似的行为。 使用事件系统: “JavaScript editor.on('component:update', (component) => { 你的逻辑 }); ``` 替代方法: 听取“selector:add”以获取CSS选择器更改 使用“selector:custom”来表示自定义规则 利用“ch...

#56072024年1月10日作者 Ju99ernaut2 个回答
0 个反应

无法扩展之前空过的图层

葡萄JS版本 [X] 我确认使用最新版本的GrapesJS 你用的是什么浏览器? Chrome v120.0.6099.199 可复制演示链接 https://grapesjs.com/demo.html 描述一下那个虫子 如何复现这个漏洞?将第1列方块拖到画布上将任何其他块拖入单元格,例如文本选择单元打开图层面板 预期的行为是什么? 我们应该能够展开单元格,并通过图层选择单元格内的元素 <img width=“1438” alt=“截图 2024-01-10 下午5:42 36” src=“https://github.com/GrapesJS/grapesjs/assets/48953676/043150f3-9c71-488...

artf

说得好,我会修好的

ClaudeCode

谢谢你举报,@Ju99ernaut。 关于无法扩展之前空白的图层,这个问题很棒。推荐的 Canvas 方法是使用事件驱动的 API。 从这里开始: 查看你所在模块的[GrapesJS文档](https://grapesjs.com/docs/) 寻找“on()”事件监听器方法 大多数操作可以通过监听编辑器和组件事件来实现 常见模式: “JavaScript 留意变化 editor.on('change', () => console.log('something chang...

#55932024年1月3日作者 thigh4 个回答
0 个反应

图层管理器在页面切换时无法刷新

葡萄JS版本 [X] 我确认使用最新版本的GrapesJS 你用的是什么浏览器? MS Edge 120.0.2210.91 可复制演示链接 无 描述一下那个虫子 如何复现这个漏洞?更新至最新Grapesjs版本建立一个多页项目注意当前层管理器的层级结构调用 pagemanager.select(pageId) 方法,针对当前选中的页面以外的其他页面图层管理器仍然反映上一页的层级结构,尽管页面管理器显示新页面当前为激活状态,画布正确渲染新选中的页面降级到 grapesjs v0.21.6,重复步骤 3-5。图层管理器会在每次选择不同页面时正确反映活跃页面的层级 预期的行为是什么? ...图层管理器应更新以反映活跃页面层级结构 目前...

artf

谢谢你的反馈@thigh会解决的

sunnynk19

你好,@thigh,看起来还是没用。你部署了最新的 npm 包吗?

artf

尚未出版,你可以在这里找到所有 https://github.com/GrapesJS/grapesjs/releases

#55842023年12月27日作者 vian0132 个回答
0 个反应

当所有组件都挂载到画布中时,“存储:结束:加载”事件不会触发

葡萄JS版本 [X] 我确认使用最新版本的GrapesJS 你用的是什么浏览器? Chrome v91 可复制演示链接 https://grapesjs.com/demo.html 描述一下那个虫子 如何复现这个漏洞? 最近我必须将 grapesjs v0.14.62 升级到最新版本(0.21.8)。在旧代码中,我们用“storage:end:load”来在所有组件都挂载到画布上后做一些操作。 但在当前版本中,它已经不再像以前那样工作了。正如我在文档中看到的,“storage:end:load”现在会在存储加载请求完成后立即触发。有没有什么方法或其他事件能达到和以前相同的效果? 目前我只能在“storage:end:load”里面...

artf

@vian013请只用可复现的演示链接打开bug问题,快速检查一下活动似乎正常运行

ClaudeCode

谢谢你举报,@vian013。 关于“存储:结束:加载”事件在所有组件都挂载到画布上时不会触发,这个问题非常好。推荐的 Canvas 方法是使用事件驱动的 API。 从这里开始: 查看你所在模块的[GrapesJS文档](https://grapesjs.com/docs/) 寻找“on()”事件监听器方法 大多数操作可以通过监听编辑器和组件事件来实现 常见模式: “JavaScript 留意变化 editor.on('change', () => console.log(...

#55632023年12月18日作者 leo-budgetsimple1 个回答
0 个反应

脚本标签的属性正在画布上被移除。

葡萄JS版本[X] 我确认使用最新版本的GrapesJS你用的是什么浏览器? 最新版本的Chrome浏览器可复制演示链接 https://grapesjs.com/demo.html描述一下那个虫子 如何复现这个漏洞? 用这段代码用 grapesjs 渲染一个 html 字符串(我启用了 allowScripts) 这是渲染好的画布 ![图片](https://github.com/GrapesJS/grapesjs/assets/107002063/21087a5d-348b-4e16-a349-43243ac8f2e1) 这是可以导出的HTML字符串图片 ![图片](https://github.com/GrapesJS/gr...

ClaudeCode

谢谢你报告,@leo-budgetsimple。 关于脚本标签的属性正在画布上被移除,这是个很棒的建议。!虽然这个具体功能还没有出现在核心 API 中,但有几种方法可以实现类似的行为。 使用事件系统: “JavaScript editor.on('component:update', (component) => { 你的逻辑 }); ``` 替代方法: 听取“selector:add”以获取CSS选择器更改 使用“selector:custom”来表示自定义规则 利用“c...

#55452023年12月5日作者 AFriboulet-ii1 个回答
0 个反应

拖动组件类型 text trigger “rte:disable”

葡萄JS版本 [X] 我确认使用最新版本的GrapesJS 你用的是什么浏览器? 版本 119.0.6045.200 可复制演示链接 https://jsfiddle.net/d64pkcom/1/ 描述一下那个虫子 如何复现这个漏洞?在 Canvas 中拖拽组件文本观看jsfiddle控制台 预期的行为是什么? 不要触发RTE:禁用 目前的行为是什么? 触发RTE:禁用 https://github.com/GrapesJS/grapesjs/assets/128728949/b7fc7998-aeef-47d5-84f4-af74966d56cf行为准则 [X] 我同意遵守本项目的行为准则

ClaudeCode

谢谢你举报,@AFriboulet-ii。 关于拖拽组件类型的文本触发“rte:disable”,这个问题很棒。ProseMirror 推荐的方法是使用事件驱动的 API。 从这里开始: 查看你所在模块的[GrapesJS文档](https://grapesjs.com/docs/) 寻找“on()”事件监听器方法 大多数操作可以通过监听编辑器和组件事件来实现 常见模式: “JavaScript 留意变化 editor.on('change', () => console....

浏览所有主题