Omi v1.0.2发布正式支持传递javascript表达式


Posted in Javascript onMarch 21, 2017

写在前面

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表达式,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
javascript静态的url如何传递
May 03 Javascript
30个精美的jQuery幻灯片效果插件和教程
Aug 23 Javascript
IE下使用cloneNode注意事项分享
Nov 22 Javascript
一款jquery特效编写的大度宽屏焦点图切换特效的实例代码
Aug 05 Javascript
JavaScript实现彩虹文字效果的方法
Apr 16 Javascript
AngularJS基础 ng-repeat 指令简单示例
Aug 03 Javascript
jQuery实现的事件绑定功能基本示例
Oct 11 jQuery
微信小程序中使用ECharts 异步加载数据实现图表功能
Jul 13 Javascript
jQuery实现的监听导航滚动置顶状态功能示例
Jul 23 jQuery
Vue 进阶之路(三)
Apr 18 Javascript
elementui之el-tebs浏览器卡死的问题和使用报错未注册问题
Jul 06 Javascript
浅谈vue中document.getElementById()拿到的是原值的问题
Jul 26 Javascript
jQuery插件HighCharts绘制简单2D柱状图效果示例【附demo源码】
Mar 21 #jQuery
jQuery插件HighCharts绘制简单2D折线图效果示例【附demo源码】
Mar 21 #jQuery
jQuery插件HighCharts绘制2D饼图效果示例【附demo源码下载】
Mar 21 #jQuery
80%应聘者都不及格的JS面试题
Mar 21 #Javascript
使用jQuery监听扫码枪输入并禁止手动输入的实现方法(推荐)
Mar 21 #jQuery
JavaScript中的普通函数和箭头函数的区别和用法详解
Mar 21 #Javascript
JavaScript 中 apply 、call 的详解
Mar 21 #Javascript
You might like
用PHP4访问Oracle815
2006/10/09 PHP
ajax+php打造进度条代码[readyState各状态说明]
2010/04/12 PHP
完整显示当前日期和时间的JS代码
2007/09/17 Javascript
老生常谈 关于JavaScript的类的继承
2016/06/24 Javascript
vue实现动态数据绑定
2017/04/28 Javascript
jquery处理checkbox(复选框)是否被选中实例代码
2017/06/12 jQuery
浅谈mvvm-simple双向绑定简单实现
2018/04/18 Javascript
详解vuex结合localstorage动态监听storage的变化
2018/05/03 Javascript
JavaScript实现浅拷贝与深拷贝的方法分析
2018/07/05 Javascript
微信小程序实现蓝牙打印
2019/09/23 Javascript
JavaScript字符串处理常见操作方法小结
2019/11/15 Javascript
Linux环境下MySQL-python安装过程分享
2015/02/02 Python
Python2.x中str与unicode相关问题的解决方法
2015/03/30 Python
Python的Flask框架应用程序实现使用QQ账号登录的方法
2016/06/07 Python
python字典DICT类型合并详解
2017/08/17 Python
python分布式环境下的限流器的示例
2017/10/26 Python
Python中eval带来的潜在风险代码分析
2017/12/11 Python
Python数据报表之Excel操作模块用法分析
2019/03/11 Python
python面向对象实现名片管理系统文件版
2019/04/26 Python
python实现按行分割文件
2019/07/22 Python
Python学习笔记之For循环用法详解
2019/08/14 Python
Python实现微信中找回好友、群聊用户撤回的消息功能示例
2019/08/23 Python
python中not、and和or的优先级与详细用法介绍
2020/11/03 Python
python 模块导入问题汇总
2021/02/01 Python
基于CSS3特效之动画:animation的应用
2013/05/09 HTML / CSS
大学生毕业的自我鉴定
2013/11/13 职场文书
教育学专业毕业生的自我鉴定
2013/11/26 职场文书
社区安全检查制度
2014/02/03 职场文书
母亲节感恩寄语
2014/02/21 职场文书
精彩的广告词
2014/03/19 职场文书
农民工工资承诺书范文
2014/03/31 职场文书
2015年办公室人员工作总结
2015/05/15 职场文书
幼儿园托班教育随笔
2015/08/14 职场文书
2020年元旦祝福语录,总有适合你的
2019/12/31 职场文书
Linux中Nginx的防盗链和优化的实现代码
2021/06/20 Servers
详解在SQLPlus中实现上下键翻查历史命令的功能
2022/03/18 SQL Server