欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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

程序员文章站 2022-04-26 17:31:20
写在前面 omi框架可以通过在组件上声明 data-* 把属性传递给子节点。 omi从设计之初,就是往标准的dom标签的标准传递方式靠齐。比如: 下划线自动转...

写在前面

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");

当然,在子组件中,你也可以不使用 的语法去遍历,使用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不包含模板引擎。

以上所述是小编给大家介绍的omi v1.0.2发布正式支持传递javascript表达式,希望对大家有所帮助