GrapesJS 问题

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

找到 466 个问题

🔍 components
#49652023年3月8日作者 RohitLad1 个回答
0 个反应

PropertyComposite 带滑块,适用于四边(左、右、右、B)。一个滑块的变动会导致其他数值重置。

葡萄JS版本 [X] 我确认使用最新版本的GrapesJS 你用的是什么浏览器? 狩猎 可复制演示链接 https://codesandbox.io/s/funny-williamson-thb52d?file=/index.js 描述一下那个虫子 如何复现这个漏洞?前往 https://codesandbox.io/s/funny-williamson-thb52d?file=/index.js 预期的行为是什么? 选择默认组件,看看样式管理器。当一个滑块(例如,底部填充)移动后,其他滑块应保持在预定义或恒定值。有趣的是,如果类型是“number”而不是“slider”,它就能正常工作 目前的行为是什么? 当移动一个滑块时(例如...

ClaudeCode

谢谢你举报,@RohitLad。 关于PropertyComposite带四边滑块(左、右、右、B)的好问题。一个滑块的变动会导致其他数值重置。推荐的 StyleManager 方法是使用事件驱动的 API。 从这里开始: 查看你所在模块的[GrapesJS文档](https://grapesjs.com/docs/) 寻找“on()”事件监听器方法 大多数操作可以通过监听编辑器和组件事件来实现 常见模式: “JavaScript 留意变化 editor.on('chang...

#49472023年2月27日作者 FaisalShaikhHA4 个回答
2 个反应

撤销管理器在撤销移除操作时无法正常工作

葡萄JS版本[X] 我确认使用最新版本的GrapesJS你用的是什么浏览器? Chrome - 版本 110.0.5481.100(官方构建)(arm64)可复制演示链接 https://codepen.io/faisal-praella/pen/ExeNwxJ描述一下那个虫子我添加了一个自定义的columns组件,带有编号特征名称columns,用于添加或移除子组件列。当我用该特性添加新列并撤销更改时,效果正常,但当我移除列并撤销更改时,会多加一列。这可能是因为当Grapesjs撤销移除更改时,它会附加已移除的列并还原列特征,但该列特征的更改触发了“this.listenTo(this, ”change:columns“, th...

artf

是的,撤销会触发“change:columns”,在你的情况下,你可以尝试用“editor”封装你的“updateColumns”更改。UndoManager.skip'。 “''js updateColumns() { 编辑。UndoManager.skip(() => { 你的行动 }) } ```

artf

好的,那我就关闭这个,请打开一个与复选框特性相关的新漏洞问题。

FaisalShaikhHA

谢谢你,@artf它有效,为了解决这个问题,我之前通过听“撤销命令”和“运行事件”来切换特质更改监听器,但这样感觉更干净了。 复选框特性在撤销/重做时未被勾选或取消勾选(我这边的特征值会更新)。可在Grapesjs网页[demo](https://grapesjs.com/demo.html)上复现。这里也需要帮助,再次感谢。 https://user-images.githubusercontent.com/102785785/224402423-fd04268a-896...

#49192023年2月8日作者 maliuta-oleksandr2 个回答
0 个反应

调用 destroy 方法会破坏编辑器(React 应用)

葡萄JS版本 [X] 我确认使用最新版本的GrapesJS 你用的是什么浏览器? Chrome 109.0.5414.119 可复制演示链接 描述一下那个虫子 如何复现这个漏洞?将事件监听器添加到外部点击调用销毁方法 预期的行为是什么?无错误销毁 目前的行为是什么? 解析器未定义,但它尝试调用其方法。 未捕获(在promise中)类型错误:无法读取未定义属性(读取“parseHtml”) 呼叫堆栈: 行为准则 [X] 我同意遵守本项目的行为准则

artf

你能提供一个可复现的演示吗?因为我这边无法复现。

ClaudeCode

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

#49062023年2月6日作者 panditlakshya2 个回答
0 个反应

Grapesjs 在通过脚本设置 innerHTML 时无法识别组件类型。

葡萄JS版本 [X] 我确认使用最新版本的GrapesJS 你用的是什么浏览器? Chrome v108.0.5359.98 可复制演示链接 https://codesandbox.io/s/grapes-js-template-literal-forked-6kgvrb?file=/src/App.js 描述一下那个虫子 我正在尝试创建一个自定义组件,通过脚本注入HTML代码后,能够识别内部HTML组件类型。 如何复现这个漏洞?直接通过脚本注入 HTML 预期的行为是什么? Canvas 应该能在注入代码后识别文本、图片等组件类型。 目前的行为是什么? 注入部分被识别为整个文本组件。(注入代码可以包含带有图像或文本的div元素)...

artf

请仔细阅读[本指南](https://grapesjs.com/docs/modules/Components-js.html),“脚本”中的所有内容都不在编辑器的权限范围内。你可以用 [component.components](https://grapesjs.com/docs/api/component.html#components) 方法更新组件本身,或者直接在定义中指定 'components: '<div ....'。

ClaudeCode

谢谢你举报,@panditlakshya。 关于Grapesjs在通过脚本设置innerHTML时无法识别组件类型,这个问题非常好。推荐的 Canvas 方法是使用事件驱动的 API。 从这里开始: 查看你所在模块的[GrapesJS文档](https://grapesjs.com/docs/) 寻找“on()”事件监听器方法 大多数操作可以通过监听编辑器和组件事件来实现 常见模式: “JavaScript 留意变化 editor.on('change', () => co...

#49042023年2月5日作者 handhikadj2 个回答
0 个反应

GetHtml() 在 js 中产生无效结构

葡萄JS版本[X] 我确认使用最新版本的GrapesJS你用的是什么浏览器? Chrome最新可复制演示链接 https://jsfiddle.net/snj87o6f/1/描述一下那个虫子 背景/描述 我觉得这是个bug,因为我需要保存数据,然后用编辑器重新加载。storageManager onStore 上的 Parser.parseHtml。更糟的是,图层管理器的结构在刷新页面时(onLoad运行)会出问题。看起来像编辑器。Parser.parseHtml() 无法正确解析它 如何复现这个漏洞?拖放倒计时块到画布上查看控制台 预期的行为是什么? 即使里面有 js,也能生成有效的 html,这样在 storageManage...

artf

输出是正确的(检查真实控制台,而不是 jsfiddle 坏掉的那个),仔细阅读[本节](https://grapesjs.com/docs/modules/Storage.html#project-data),绝不应该依赖 HTML/CSS 来加载项目。

ClaudeCode

谢谢你举报,@handhikadj。 关于getHtml()在里面有js时生成无效结构的建议很棒!虽然这个具体功能还没有出现在核心 API 中,但有几种方法可以实现类似的行为。 使用事件系统: “JavaScript editor.on('component:update', (component) => { 你的逻辑 }); ``` 替代方法: 听取“selector:add”以获取CSS选择器更改 使用“selector:custom”来表示自定义规则 利用“chang...

#49002023年2月5日作者 handhikadj2 个回答
0 个反应

SetStyle/getCss() 生成重复的 CSS

葡萄JS版本[X] 我确认使用最新版本的GrapesJS你用的是什么浏览器? Chrome 最新动态可复制演示链接 https://codesandbox.io/s/silent-river-ifczcv描述一下那个虫子 如何复现这个漏洞?访问网站参见控制台。注意“”和“body”选择器 预期结果 不应重复 如果需要执行某些代码以重现该漏洞,请将其粘贴到下面: “''js editor = grapesjs.init({ storageManager:false // ... }) editor.on(“update”, () => { 保存到后端 console.log(“editor getCSs”, editor.getCs...

artf

有一些默认样式应用,你可以简单地禁用(传递空字符串)https://github.com/GrapesJS/grapesjs/blob/a83847b1b35e69e5a5810ccf1eb1e1384bf0aab1/src/editor/config/config.ts#L143-L147

ClaudeCode

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

#48972023年2月3日作者 rudacs4 个回答
1 个反应

Component:styleUpdate / component:styleUpdate:propertyName 未被触发

葡萄JS版本 [X] 我确认使用最新版本的GrapesJS 你用的是什么浏览器? Edge 109.0.1518.70 可复制演示链接 https://jsfiddle.net/rudacs/kr2x1mnh/ 描述一下那个虫子 如何复现这个漏洞?在 StyleManager 中更改某些属性。更改 StyleManager 中的宽度属性。 预期的行为是什么? 事件 component:styleUpdate 被触发。 目前的行为是什么? 不会触发任何事件 component:styleUpdate。 行为准则 [X] 我同意遵守本项目的行为准则

artf

嘿,@rudacs你试过用'style:property:update'吗?

rudacs

这个活动奏效了。它被改成了这个吗? 而且只针对一处房产? 我该如何获得组件和属性被更改的? 特朗克。

SagarMaria

我来这里是因为我也有同样的问题。 使用建议的“style:property:update”似乎有效,但不知为何每次点击都会触发。 另外,我们如何针对某个特定的样式属性变更,比如“文本对齐”?

#48682023年1月26日作者 LukasSouza2 个回答
1 个反应

悬停的框在更改编辑器位置后显示错位

葡萄JS版本 [X] 我确认使用最新版本的GrapesJS 你用的是什么浏览器? Chrome 109.0.5414.87 可复制演示链接 https://jsfiddle.net/o45ncveu/6/ 描述一下那个虫子 如何复现这个漏洞?打开小提琴链接在超时前悬停部分组件等待时间结束以添加边距并更改编辑位置再次悬停组件 预期的行为是什么? 悬浮方块应与组件边距对齐 目前的行为是什么? 更改编辑器位置后,悬停方块显示与组件错位行为准则 [X] 我同意遵守本项目的行为准则

artf

不幸的是,这是预期中的,你必须在“外部”布局更改后使用 'editor.refresh()'。

ClaudeCode

谢谢你举报,@LukasSouza。 安全和依赖性问题很重要。GrapesJS 团队积极致力于保持依赖系统的更新。 为你现在: 运行“npm审计修复”以查看可用的补丁 查看是否有更新的GrapesJS版本,可能已经解决了这个问题 如有稳定版,升级前先测试最新稳定版 如果漏洞非常严重,可以使用“npm audit fix --force”,但请务必彻底测试 理解风险: 在GitHub安全公告中查看具体漏洞详情 并非所有高严重性问题都会影响你的代码路径 某些漏洞仅在特定条件下触...

#48552023年1月19日作者 ronaldohoch4 个回答
1 个反应

应用 loadProjectData 后,轮廓会消失

葡萄JS版本 [X] 我确认使用最新版本的GrapesJS 你用的是什么浏览器? 勇敢的最后版本 可复制演示链接 https://grapesjs.com/demo 描述一下那个虫子 如何复现这个漏洞?打开演示页面打开开发者工具运行: 'let projectData = editor.getProjectData()'跑:'编辑。DomComponents.clear()'运行:editor.loadProjectData(projectData); 预期的行为是什么? 组件轮廓应被展示。 目前的行为是什么? 应用项目后,组件的轮廓没有显示。行为准则 [X] 我同意遵守本项目的行为准则

allenhwkim

@ronaldohoch用Edge浏览器,它用的是你提供的命令。 'let projectData = editor.getProjectData();' “编辑。DomComponents.clear();' 'editor.loadProjectData(projectData);' 我觉得GrapesJS不支持Brave浏览器,而Brave浏览器在 https://github.com/browserslist/caniuse-lite 里没有列出。 <img wid...

ronaldohoch

我还运行了命令 'editor.runCommand(“core:component-outline”)',但又没显示,我需要点击按钮两次才能显示

ronaldohoch

你好,@allenhwkim,谢谢你的评论。但尴尬的是我没在其他浏览器里测试。 我相信我的客户不使用Brave,所以我打算放弃这部分。 不过,通过所有这些测试,我成功地让它按我想要的方式工作,应用了以下代码: “''js editor.loadProjectData(JSON.parse(sessionStorage.getItem(commandOpts.value))); if(editor.Commands.isActive(“sw-visibility”){ 编辑。...

#48542023年1月19日作者 mnutt4 个回答
1 个反应

导出“default”,但“backbone”中找不到(模块没有导出功能)

葡萄JS版本 [X] 我确认使用最新版本的GrapesJS 你用的是什么浏览器? Firefox 109 可复制演示链接 没有 描述一下那个虫子 如何复现这个漏洞? 预期的行为是什么? 开发服务器启动。 目前的行为是什么? 我用的是node v16.18.1(MacOS),虽然在节点14和节点18上也出现了同样的结果。是不是我做错了什么明显的错误? 行为准则 [X] 我同意遵守本项目的行为准则

mnutt

是的,我也能用“grapesjs-style-filter”重现,同样的错误类型。

mnutt

我通过修改构建流程,通过“--targets=”“> 3%”'来绕过了这个错误,但由于使用es6类,这会导致骨干错误。

artf

我这边用全新安装无法复现,你用的是开发分支吗?

浏览所有主题