基于vue3的样式绑定解决方案

前言

​ 在完成组件样式编辑器之后,在测试的过程中发现要是想将配置的组件样式进行复用,可以通过粘贴复制组件来实现,不过这就有一个问题,此样式不能应用到已存在的画布中的组件上,并且不能应用到其他组件上,要是想要配置相同样式还需要一点点修改配置,这就在让样式配置很头疼了。
在这时看到了阿里的lowcode-engine,在其源码面板处有index.css配置,可以通过类名进行与组件的绑定。发现这正是我想要的效果,通过这种编写.css,进行类名的绑定,可以灵活运用到画布中的组件上,省去了一个个编写组件样式的麻烦,解决方案有了那就开干!
项目源码地址要是觉着有意思的化,不妨留下一颗星

实现方式

​ 由于本项目使用的是vue框架,便想到可以通过v-html的方式来给页面增加

的方式完成class的绑定。

示例代码:

<div v-html="`<style>${css}</style>`"></div>
<component
    :class="item.bindClass"
/>

效果如下:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-U3L3BXmf-1691121875032)(C:\Users\22866\Desktop\证件照\easycode\B000AF19-527F-4432-91BA-46C02C940D80.png)]

​ 可以看到已经实现了样式的动态绑定,至此心想这功能不就完成了!正高兴的时候突然想到v-html是将

样式污染的解决方案

iframe方案

​ 想到样式编辑的灵感来源于lowcode-engine,便想着去看看人家是怎么解决的这个问题,打开lowcode-engine 查看网页源码,发现他是在画布之上套了一层iframe这样编写的样式便不会污染到画布之外的地方。

​ 开始尝试,将画布组件注册到路由当中,通过iframe进行调用…,经过一系列的改造,测试一下双击画布中的组件发现组件编辑器没有响应,这一改造把原有的功能给干掉了,人麻了!排查原因,组件之间的数据互通是通过pinia的方式,画布页面是通过frame的方式嵌套在页面上,iframe 中的源pinia与外层页面的pinia数据不互通,要想互通还需要引入pinia的数据持久化,将pinia的数据保存到localStorage中进行数据的互通,考虑到会有多个页面,众多组件,执行效率等问题就没采用这个解决方案。

PostCSS方案

​ 在iframe方案pass后,开始重新思考解决方案,由于迟迟没想到解决方案,开发也不能卡在这个点上不是,在修改样式的时候注意到了vue的

安装PostCSS

npm install postcss

新建一个postcss-selector-add.js 用于实现属性选择器的绑定

import postcss from "postcss";
export const ecPostcss = postcss.plugin('postcss-selector-add', function (opts) {
    return function (root, result) {
        
        root.walkRules(function (rule) {
            rule.selector =  `${selectorValue} ${rule.selector}`
        });
    };
});
let selectorValue =''
export function setAttr(attr,value){
    if(attr && value){
        selectorValue = `[${attr}="${value}"]`
    }
}

调用

import postcss from "postcss";
import {ecPostcss} from "@/utils/postcss-selector-add";

postcss(ecPostcss).process('源css文本').then(result => {
  that.cssfinal = result.css
})

在画布上增加特定的标识属性,便可进行样式隔离,至此样式绑定功能完成!

​ 由于本人对PostCSS的使用只是皮毛,在此就不细讲PostCSS了,大家想要学习可以搜索PostCSS的官网,或者站内也有不少写PostCSS相关的博客。

由于本人对PostCSS的使用只是皮毛,在此就不细讲PostCSS了,大家想要学习可以搜索PostCSS的官网,或者站内也有不少写PostCSS相关的博客。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 基于Vue开发的组态编辑器已经有很多开源项目可以使用。Vue是一种流行的JavaScript框架,适用于构建现代且高效的用户界面。 组态编辑器是一种可以帮助开发人员和设计师创建和编辑用户界面的工具。它通常提供了一个可视化界面,允许用户拖放和配置各种组件,并生成相应的代码。 通过使用Vue,开源的组态编辑器可以充分利用Vue的特性。Vue的组件化架构使得创建和嵌套组件变得非常容易,这使得组态编辑器可以提供丰富的组件库以及快速配置和编辑的功能。 这些开源的基于Vue的组态编辑器提供了灵活的自定义选项,可以根据用户的需求进行扩展和定制。通过使用Vue的生态系统中的其他工具和库,如Vuex和Vue Router,组态编辑器可以实现更复杂的功能,如状态管理和路由。 开源的组态编辑器项目还提供了强大的社区支持。开发者可以从其他用户的经验中获益,找到解决问题的方法,并与其他人共享自己的成果。 总之,基于Vue开发的开源组态编辑器是一个非常有用的工具,可以帮助开发人员和设计人员更轻松地创建和编辑用户界面。它利用了Vue的特性和生态系统,并通过强大的社区支持提供了一个简单而灵活的解决方案。 ### 回答2: 基于Vue开发的组态编辑器是一种用于创建、编辑和管理可视化组态的开源工具。它是使用Vue框架开发的,通过Vue的响应式数据绑定、组件化和虚拟DOM等特性,具备高效、灵活和可扩展的特点。 作为一个开源项目,基于Vue开发的组态编辑器允许用户自由使用、修改和分发。这意味着用户可以根据自己的需求自定义组态编辑器的功能、扩展其特性,甚至与其他项目进行集成。这种开源的特性使得组态编辑器具有更高的可定制性和可持续性。 基于Vue开发的组态编辑器不仅可以用于创建静态的组态界面,还可以通过各种交互元素(如按钮、输入框等)实现动态的组态效果。它提供了丰富的组件库,包括图表、控件、容器等,用户可以直接拖拽并配置这些组件来构建自己的组态界面。同时,组态编辑器还支持导入、导出组态配置,方便用户在不同项目之间进行共享和迁移。 基于Vue的组态编辑器具有良好的用户界面和用户体验,通过直观的操作和友好的设计,使用户能够轻松地创建、编辑和管理组态界面。它还提供了丰富的文档和示例,帮助用户快速上手并掌握使用技巧。 总之,基于Vue开发的组态编辑器是一个功能丰富、高度可定制和易于使用的开源工具,可以帮助开发者高效地创建和管理可视化组态界面。无论是个人开发者还是企业项目,都可以从中受益并加速开发进程。 ### 回答3: 基于Vue开发的组态编辑器目前是开源的。组态编辑器是一种可帮助用户设计和配置工控系统界面的工具,Vue作为一种流行的JavaScript框架,在开发过程中提供了诸多便利和灵活性。 开源的组态编辑器可以使用户更容易地创建和定制工控系统界面。它提供了一套易于使用和交互友好的界面组件,可以方便地拖拽、缩放和配置,以实现个性化的界面设计。用户可以根据需求自定义各种组件的样式、布局和交互行为。 基于Vue框架的组态编辑器还具备一些高级功能,如数据绑定和响应式设计。它可以与后端服务器进行数据交互,实现动态的数据展示和更新。同时,在用户修改界面配置时,可以实时反映在界面上,减少开发者的调试时间。 由于是开源的,组态编辑器还具备扩展性和可定制性。开发者可以根据自己的需求进行二次开发和定制,添加新的功能或者修改现有功能。同时,开源社区的积极参与也可以提供更多的插件和扩展,丰富组态编辑器的功能。 总的来说,基于Vue开发的组态编辑器具有易用性、灵活性和扩展性等优势。它为用户提供了一种方便快捷的方式来设计和定制工控系统界面,帮助用户实现个性化的界面配置。开源的特性也使得组态编辑器可以更好地适应不同的需求,并获得更多的改进和支持。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值