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性能解析【教程】