2017年试试Web组件化框架Omi

Omi

Open and modern framework for building user interfaces. css


  • Omi的Github地址https://github.com/AlloyTeam/omi
  • 若是想体验一下Omi框架,能够访问 Omi Playground
  • 若是想使用Omi框架或者开发完善Omi框架,能够访问 Omi使用文档
  • 若是你想得到更佳的阅读体验,能够访问 Docs Website
  • 若是你懒得搭建项目脚手架,能够试试 omi-cli
  • 若是你有Omi相关的问题能够 New issue
  • 若是想更加方便的交流关于Omi的一切能够加入QQ的Omi交流群(256426170)

特性

  • 超小的尺寸,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  `
            <style>
                h1{
                    cursor:pointer;
                }
            </style>
         `;
    }
    handleClick(target, evt){
        alert(target.innerHTML);
    }
    render() {
        return  `
        <div>
            <h1 onclick="handleClick(this, event)">Hello ,{{name}}!</h1>
        </div>
        `;

    }
}

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

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

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

Omi.makeHTML('Hello', Hello);

那么你就在其余组件中使用,而且经过data-*的方式能够给组件传参,如:git

...
  render() {
        return  `
        <div>
            <div>Test</div>
            <Hello data-name="Omi" />
        </div>
        `;
    }
    ...

注意,style方法里面return包裹的<style></style>不是必须的。主要是方便识别成jsx文件时候有css语法高亮。github

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

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

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

ES5方式

var Hello =  Omi.create("Hello", {
    style: function () {
        return "<style>h1{ cursor:pointer }</style>";
    },
    handleClick: function (dom) {
        alert(dom.innerHTML)
    },
    render: function () {
        return ' <div><h1 onclick="handleClick(this, event)">Hello ,{{name}}!</h1></div>'
    }
});

var Test =  Omi.create("Test", {
    render: function () {
        return '<div>\
                    <div>Test</div>\
                    <Hello data-name="Omi" />\
                </div>'
    }
});

Omi.render(new Test(),'#test');

和ES6+的方式不一样的是,再也不须要makeHTML来制做标签用于嵌套,由于 Omi.create的第一个参数的名称就是标签名。框架

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

加入Omi吧!

Github: https://github.com/AlloyTeam/omi

I need you.

相关文章
相关标签/搜索