2017年試試Web組件化框架Omi


Omi

Open and modern framework for building user interfaces.

--- * Omi的Github地址[https://github.com/AlloyTeam/omi](https://github.com/AlloyTeam/omi) * 如果想體驗一下Omi框架,可以訪問 [Omi Playground](http://alloyteam.github.io/omi/example/playground/) * 如果想使用Omi框架或者開發完善Omi框架,可以訪問 [Omi使用文檔](https://github.com/AlloyTeam/omi/tree/master/docs#omi使用文檔) * 如果你想獲得更佳的閱讀體驗,可以訪問 [Docs Website](http://alloyteam.github.io/omi/website/docs.html) * 如果你懶得搭建項目腳手架,可以試試 [omi-cli](https://github.com/AlloyTeam/omi/tree/master/cli) * 如果你有Omi相關的問題可以 [New issue](https://github.com/AlloyTeam/omi/issues/new) * 如果想更加方便的交流關於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");

[點擊這里->在線試試]

你可以使用Omi.makeHTML來生成組件標簽用於嵌套。

    Omi.makeHTML('Hello', Hello);

那么你就在其他組件中使用,並且通過data-*的方式可以給組件傳參,如:

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

注意,style方法里面return包裹的<style></style>不是必須的。主要是方便識別成jsx文件時候有css語法高亮。

[點擊這里->在線試試]

你可以使用 webpack + babel,在webpack配置的module設置babel-loader,立馬就能使用ES6+來編寫你的web程序。

當然Omi沒有拋棄ES5的用戶,你可以使用ES5的方式編寫Omi。

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程序]

加入Omi吧!

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

I need you.


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM