摘要:目前來看,團隊內(nèi)部前端項目已全面實施組件化開發(fā)。層疊樣式保佑不要污染別的在前端,一般一個組件必須要有骨架和裝飾的以及邏輯。事件綁定條件判斷秒后改變,會自動變更。循環(huán)姓名年齡增加修改移除的變更也能監(jiān)聽到,能夠自動觸發(fā)的變更。
目前來看,團隊內(nèi)部前端項目已全面實施組件化開發(fā)。組件化的好處太多,如:按需加載、可復(fù)用、易維護、可擴展、少挖坑、不改組件代碼直接切成服務(wù)器端渲染(如Nuclear組件化可以做到,大家叫同構(gòu))...
怎么做到這么強大的優(yōu)勢,來回憶下以前見過的坑,或者現(xiàn)有項目里的坑。
在web前端,一般一個組件必須要有骨架HTML和裝飾的CSS以及JS邏輯。而CSS要是可以是局部作用域那就再好不過了!就不用寫長長的前綴了,浪費帶寬不說,而且費勁。
如
.ui-popup-arrow-xx-xxxxx-xxxx-container { }
這回夠長了吧,不會污染別的HTML了吧。真的太長了,沒有辦法,因為CSS不是局部的,怕污染其他的HTML,規(guī)劃好長長的namespace、module是以前的最佳實踐。
怎么優(yōu)雅綁定事件?只能定義在window下?如果HTML綁定的事件是局部作用域那就再好不過了!我真的見過模版代碼里出現(xiàn)下面的代碼:
然后在js里找到了下面的代碼:
要綁定的事件一多,得污染多少全局變量啊。所以還有的工程師這么干:
然后在js里找到了下面的代碼:
這里貌似比不設(shè)定namespace好很多,但是還是妥協(xié)的結(jié)果。一般希望能封裝成組件,組件的HTML里綁定的事件就是組件內(nèi)定義的事件,內(nèi)聚內(nèi)聚!!
通過js動態(tài)綁定事件的壞處我以前專門寫了一篇文章來闡述,主要是lazy bind會導(dǎo)致用戶看到了頁面,但是頁面確無法響應(yīng)用戶的交互,這里不再闡述。
大型項目如游戲什么的為啥都是面向?qū)ο笫降膶懛ǎ咳绻粋€組件剛好又能是一個Class那就再好不過,Class base可以更方便地抽象現(xiàn)實世界的物體及其屬性或者邏輯算法,所以甚至有些編程語言都是面向?qū)ο蟮?這里逆向邏輯),如JAVA、C#...整體過程式的代碼對于大型項目幾乎沒法維護(如基于jQuery就能容易寫出整體都是過程式的組織結(jié)構(gòu)),整體OO,局部過程式是可以接受的。
組件需要嵌套?只能復(fù)制粘貼原組件?扁平無嵌套組件還是比較簡單,對模板的字符串處理下,把綁定的事件全指向組件自身定義的方法,生命周期也好處理。在真正的業(yè)務(wù)里經(jīng)常需要組件嵌套,這樣也更利于復(fù)用。雖然大量模板引擎支持引用子模板、共享數(shù)據(jù)等,但是組件是有生命周期的,模板嵌套不能真正解決組件嵌套的問題。能支持組件嵌套并且聲明式嵌套就那就再好不過了!
數(shù)據(jù)變了?重新生成HTML替換一下?怎么替換?先查找dom?什么?你還在查找dom?你還在背誦CSS選擇器?替換一下?不能增量更新嗎?或者diff一下吧?不要每次全部替換啊!
首屏太慢?以前抽象的組件沒法復(fù)用?什么?首屏太慢?改成直出(服務(wù)器渲染)?以前代碼沒法復(fù)用?要推翻重寫?什么?怎么搞?排期?產(chǎn)品不給排期?需求沒變?yōu)槭裁匆o排期?
下面來看下Nuclear怎么解決上面問題。
install Nuclearnpm install alloynuclearHello,Nuclear!
var HelloNuclear = Nuclear.create({ render: function () { return "Hello , {{name}} !"; } }) new HelloNuclear({ name: "Nuclear" }, "body");
內(nèi)置了mustache.js無邏輯模板。
事件綁定var EventDemo = Nuclear.create({ clickHandler: function (evt, target, other1,other2) { //MouseEvent {isTrusted: true, screenX: 51, screenY: 87, clientX: 51, clientY: 21…} console.log(evt); //條件判斷Click Me!console.log(target); //otherParameter1 console.log(other1); //otherParameter2 console.log(other2); alert("Hello Nuclear!"); }, render: function () { return "Click Me!" } }) new EventDemo({ seen: true }, "body");
var ConditionDemo = Nuclear.create({ render: function () { return "{{#seen}}you can see me{{/seen}} {{^seen}}yan can not see me{{/seen}}" } }) var cd = new ConditionDemo({ seen: true }, "body"); setTimeout(function () { cd.option.seen = false; }, 2000);
2秒后改變seen,dom會自動變更。
循環(huán)var LoopDemo = Nuclear.create({ render: function () { return "
Array的變更也能監(jiān)聽到,能夠自動觸發(fā)Dom的變更。
局部CSSI"m other div!! my color is not red!!
組件外的div不會被組件內(nèi)的CSS污染。
討厭反斜杠?討厭反斜杠可以使用 ES20XX template literals、或者split to js、css和html文件然后通過構(gòu)建組裝使用。也可以用template標簽或者textare存放模板。
組件嵌套TODO
{{#items}}
- {{.}}
{{/items}}
通過在父對象的install里設(shè)置this.childrenOptions來把option傳給子節(jié)點。
服務(wù)器端渲染function todo(Nuclear,server) { var Todo = Nuclear.create({ add: function (evt) { evt.preventDefault(); this.option.items.push(this.textBox.value); }, render: function () { return ``; }, style: function () { return `h3 { color:red; } button{ color:green;}`; } },{ server:server }); return Todo; } if ( typeof module === "object" && typeof module.exports === "object" ) { module.exports = todo ; } else { this.todo = todo; }TODO
{{#items}}
- {{.}}
{{/items}}
通過第二個參數(shù)server來決定是服務(wù)器端渲染還是客戶端渲染。server使用的代碼也很簡單:
var koa = require("koa"); var serve = require("koa-static"); var router = require("koa-route"); var app = koa(); var jsdom = require("jsdom"); var Nuclear = require("alloynuclear")(jsdom.jsdom().defaultView); var Todo = require("./component/todo")(Nuclear,true); app.use(serve(__dirname + "/component")); app.use(router.get("/todos", function *(){ var str = require("fs").readFileSync(__dirname + "/view/index.html", "utf8"); var todo = new Todo({ items: ["Nuclear2","koa","ejs"] }); this.body = Nuclear.Tpl.render(str, { todo: todo.HTML }); Nuclear.destroy(todo); })); app.listen(3000);
瀏覽器端使用的代碼:
{{{todo}}}
這樣,組件的代碼不需要任何變更就可以在server和client同時使用。
Nuclear如何做到同構(gòu)的?內(nèi)置三條管線如下所示:
比如一般前后端分離的開發(fā)方式,僅僅會走中間那條管線。而同構(gòu)的管線如下所示:
這里前后后端會共用option,所以不僅僅需要直出HTML,option也會一并支持給前端用來二次渲染初始一些東西。
Nuclear優(yōu)勢1.節(jié)約流量
2.提升用戶體驗
3.加載更加靈活
4.Dom查找?guī)缀踅^跡
5.搭積木一樣寫頁面
6.提升代碼復(fù)用性
7.可插拔的模板引擎
8.Lazy CSS首屏更輕松
9.Nuclear文件大小6KB (gzip)
10.零行代碼修改無縫切到同構(gòu)直出
...
...
https://github.com/AlloyTeam/Nuclear
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/80786.html
摘要:直搗黃龍黃龍即黃龍府,轄地在今吉林一帶,應(yīng)該是指長春市農(nóng)安縣,為金人腹地。一直打到黃龍府。指搗毀敵人的巢穴。有人會說組合優(yōu)于繼承的。的變更會自動更新依賴的組件。可以操作對象實例,的變更會自動更新組件,屬性設(shè)置方法調(diào)用。 刀耕火種 刀耕火種是新石器時代殘留的農(nóng)業(yè)經(jīng)營方式。又稱遷移農(nóng)業(yè),為原始生荒耕作制。 var TodoApp = Nuclear.create({ add: f...
摘要:每個框架類庫被大量用戶大規(guī)模使用都說明其戳中了開發(fā)者的剛需。但是未執(zhí)行完的情況下發(fā)生人機交互雖然不會報腳本錯誤,但是嚴重影響用戶體驗開發(fā)者們被各種爽到之后,這個問題已經(jīng)被拋到了九霄云外。 寫在前面 因為zepto、jQuery2.x.x和Nuclear都是為現(xiàn)代瀏覽器而出現(xiàn),不兼容IE8,適合現(xiàn)代瀏覽器的web開發(fā)或者移動web/hybrid開發(fā)。每個框架類庫被大量用戶大規(guī)模使用都說明...
閱讀 3880·2021-09-23 11:51
閱讀 3067·2021-09-22 15:59
閱讀 868·2021-09-09 11:37
閱讀 2070·2021-09-08 09:45
閱讀 1267·2019-08-30 15:54
閱讀 2065·2019-08-30 15:53
閱讀 492·2019-08-29 12:12
閱讀 3290·2019-08-29 11:15