Omi v1.0.2发布正式支持传递javascript表达式
发布时间 - 2026-01-11 00:16:53 点击率:次写在前面

Omi框架可以通过在组件上声明 data-* 把属性传递给子节点。
Omi从设计之初,就是往标准的DOM标签的标准传递方式靠齐。比如:
- 下划线自动转驼峰, data-page-index传到子组件就变成this.data.pageIndex
- data-xx 传递到子节点全都变成字符串,如data-page-index="1"到子节点中this.data.pageIndex就是字符串"1"
这样会有什么局限性和问题?如:
- 无法传递JSON
- 无法传递number类型
- 无法传递bool类型
那么支持传递javascript表达式就能解决这些痛点。
废话不多说,来看神器的冒号。
冒号标记
看下面例子:
import Hello from 'hello.js'
Omi.makeHTML('Hello', Hello);
class App extends Omi.Component {
render() {
return `
<div>
<Hello :data-user="{ name : 'Dntzhang', favorite : 'Omi' }" />
</div>
`
}
}
Omi.render(new App(),"#container")
在data-user前面加上冒号即:data-user,就代表传递的是js 表达式,够方便吧。
然后在Hello组件内就可以直接使用。
class Hello extends Omi.Component {
render() {
return `
<div>
<h1>{{user.name}} love {{user.favorite}}.</h1>
</div>
`
}
}
你也可以在hello组件内打印出 this.data.user 试试。
传递其他类型
上面的例子展示了传递JSON,其他类型也支持。比如:
<Hello :data-age="18" /> <Hello :data-xxx="1+1*2/3" /> <Hello :data-is-girl="false" /> <Hello :data-array-test="[1,2,3]" />
复杂类型
最后给大家看个稍微一丁点复杂的案例:
class Hello extends Omi.Component {
handleClick(evt){
alert( this.data.arrayTest[0].name)
}
render() {
return `
<ul>
{{#arrayTest}}
<li onclick="handleClick">{{name}}</li>
{{/arrayTest}}
</ul>
`;
}
}
Omi.makeHTML('Hello', Hello);
class App extends Omi.Component {
render() {
return `
<div>
<Hello :data-array-test="[{name:'dntzhang'},{name:'omi'},{name:'AlloyTeam'}]" />
</div>
`;
}
}
Omi.render(new App(),"#container");
当然,在子组件中,你也可以不使用 mustache.js模板引擎的语法去遍历,使用ES6+的姿势去遍历。
class Hello extends Omi.Component {
render() {
return `
<ul>
${this.data.arrayTest.map(item =>
`<li>${item.name}</li>`
).join('')}
</ul>
`;
}
}
这也是为什么omi提供了两个版本,omi.js和omi.lite.js的原因。omi.lite.js不包含mustache.js模板引擎。
以上所述是小编给大家介绍的Omi v1.0.2发布正式支持传递javascript表达式,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
# Omi
# v1.0.2发布
# javascript
# 表达式
# javascript 手机号码正则表达式验证函数
# 比较正宗的验证邮箱的正则表达式js代码详解
# js 常用正则表达式表单验证代码
# 精通JS正则表达式(推荐)
# js各种验证文本框输入格式(正则表达式)
# 遍历
# 给大家
# 你也可以
# 小编
# 的是
# 就能
# 在此
# 下划线
# 可以通过
# 可以直接
# 多说
# 之初
# 所述
# 给我留言
# 感谢大家
# 会有什么
# 看个
# 不包含
# 内就
# 疑问请
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
Laravel怎么清理缓存_Laravel optimize clear命令详解
国美网站制作流程,国美电器蒸汽鍋怎么用官方网站?
如何用狗爹虚拟主机快速搭建网站?
google浏览器怎么清理缓存_谷歌浏览器清除缓存加速详细步骤
怎么制作一个起泡网,水泡粪全漏粪育肥舍冬季氨气超过25ppm,可以有哪些措施降低舍内氨气水平?
Laravel如何使用Gate和Policy进行授权?(权限控制)
网站制作壁纸教程视频,电脑壁纸网站?
Laravel怎么配置.env环境变量_Laravel生产环境敏感数据保护与读取【方法】
Python正则表达式进阶教程_复杂匹配与分组替换解析
如何用低价快速搭建高质量网站?
ChatGPT回答中断怎么办 引导AI继续输出完整内容的方法
EditPlus中的正则表达式实战(6)
如何在万网ECS上快速搭建专属网站?
JavaScript常见的五种数组去重的方式
中山网站制作网页,中山新生登记系统登记流程?
JavaScript中的标签模板是什么_它如何扩展字符串功能
装修招标网站设计制作流程,装修招标流程?
微信公众帐号开发教程之图文消息全攻略
Laravel如何实现API资源集合?(Resource Collection教程)
Laravel怎么实现模型属性转换Casting_Laravel自动将JSON字段转为数组【技巧】
网站制作免费,什么网站能看正片电影?
Windows Hello人脸识别突然无法使用
Laravel如何记录自定义日志?(Log频道配置)
Linux系统命令中tree命令详解
如何快速上传建站程序避免常见错误?
Midjourney怎样加参数调细节_Midjourney参数调整技巧【指南】
Win11怎么设置虚拟桌面 Win11新建多桌面切换操作【技巧】
Python自然语言搜索引擎项目教程_倒排索引查询优化案例
网站制作怎么样才能赚钱,用自己的电脑做服务器架设网站有什么利弊,能赚钱吗?
个人网站制作流程图片大全,个人网站如何注销?
Laravel如何处理异常和错误?(Handler示例)
如何快速搭建二级域名独立网站?
Laravel软删除怎么实现_Laravel Eloquent SoftDeletes功能使用教程
如何选择可靠的免备案建站服务器?
Laravel如何生成和使用数据填充?(Seeder和Factory示例)
Laravel如何处理CORS跨域问题_Laravel项目CORS配置与解决方案
Laravel Blade模板引擎语法_Laravel Blade布局继承用法
如何为不同团队 ID 动态生成多个“认领值班”按钮
详解免费开源的DotNet二维码操作组件ThoughtWorks.QRCode(.NET组件介绍之四)
laravel怎么通过契约(Contracts)编程_laravel契约(Contracts)编程方法
香港服务器租用每月最低只需15元?
HTML5打空格有哪些误区_新手常犯的空格使用错误【技巧】
Laravel如何自定义分页视图?(Pagination示例)
如何制作新型网站程序文件,新型止水鱼鳞网要拆除吗?
Laravel怎么设置路由分组Prefix_Laravel多级路由嵌套与命名空间隔离【步骤】
韩国代理服务器如何选?解析IP设置技巧与跨境访问优化指南
如何在HTML表单中获取用户输入并用JavaScript动态控制复利计算循环
常州企业网站制作公司,全国继续教育网怎么登录?
韩国服务器如何优化跨境访问实现高效连接?
Python文件流缓冲机制_IO性能解析【教程】

