2017年试试Web组件化框架Omi

来源:知乎 时间:2017-2-16 09:25 阅读数:158 作者:TAT.dnt

摘要:Open and modern framework for building user interfaces.

Open and modern framework for building user interfaces.

特性

  • 超小的尺寸,7 kb (gzip)
  • 局部CSS,HTML+ Scoped CSS + JS组成可复用的组件。不用担心组件的CSS会污染组件外的,Omi会帮你处理好一切
  • 更自由的更新,每个组件都有update方法,自由选择时机进行更新。你也可以和obajs或者mobx一起使用来实现自动更新。
  • 模板引擎可替换,开发者可以重写Omi.template方法来使用任意模板引擎
  • 完全面向对象,函数式和面向对象各有优劣,Omi使用完全的面向对象的方式来构建Web程序。
  • ES6+ 和 ES5都可以,Omi提供了ES6+和ES5的两种开发方案。你可以自有选择你喜爱的方式。

通过npm安装

npm install omi

Hello World

class Hello extends Omi.Component {
    constructor(data) {
        super(data);
    }
    style () {
        return  `
            h1{
                cursor:pointer;
            }
         `;
    }
    handleClick(target, evt){
        alert(target.innerHTML);
    }
    render() {
        return  `
        

Hello ,{{name}}!

`; } } Omi.render(new Hello({ name : "Omi" }),"body");

[点击这里->在线试试]

你可以使用Omi.makeHTML来生成组件标签用于嵌套。

Omi.makeHTML('Hello', Hello);

那么你就在其他组件中使用,并且通过data-*的方式可以给组件传参,如:

...
  render() {
        return  `
        
Test
`; } ...

[点击这里->在线试试]

你可以使用 webpack + babel,在webpack配置的module设置babel-loader,立马就能使用ES6+来编写你的web程序。

当然Omi没有抛弃ES5的用户,你可以使用ES5的方式编写Omi。

ES5方式

var Hello =  Omi.create("Hello", {
    style: function () {
        return "h1{ cursor:pointer }";
    },
    handleClick: function (dom) {
        alert(dom.innerHTML)
    },
    render: function () {
        return ' 

Hello ,{{name}}!

' } }); var Test = Omi.create("Test", { render: function () { return '
\
Test
\ \
' } }); Omi.render(new Test(),'#test');

和ES6+的方式不同的是,不再需要makeHTML来制作标签用于嵌套,因为 Omi.create的第一个参数的名称就是标签名。

[点击这里试试ES5写Omi程序]

加入Omi吧!

Github: AlloyTeam/omi: 开放现代的Web组件化框架-Open and modern framework for building user interfaces.

PHPChina

发布于:2017-2-16 09:25

分享到:
返回顶部
 
商务洽谈咨询
洽谈咨询
PHPChina在线客服
PHPChina在线客服