摘要:僅作用于未跟蹤的文件。作用是保存目前的工作目錄和暫存區(qū)狀態(tài),返回一個(gè)干凈的工作空間。用于標(biāo)記某次發(fā)布。模塊仍然污染了全局變量。實(shí)際返回的是這個(gè)函數(shù),參數(shù)包括模塊名,依賴的模塊,當(dāng)前模塊的實(shí)現(xiàn)。
協(xié)作流程 1.職責(zé) 頁面工程師 前端工程師 接口設(shè)計(jì) 1.頁面入口規(guī)范
基本信息
輸入?yún)?shù)模板列表
接口列表
基本信息
預(yù)填數(shù)據(jù)
注入接口
3.異步接口規(guī)范基本信息
輸入數(shù)據(jù)
輸出結(jié)果
同步請求,異步請求? 版本管理版本控制系統(tǒng)VCS (Version control system)
1.分支模型產(chǎn)品級的分支模型:
2.gitgit是一個(gè)基于內(nèi)容尋址的存儲(chǔ)系統(tǒng)?;?strong>文件內(nèi)容,而不是基于文件。
安裝
git基礎(chǔ)操作 1.git configWindows: msysgit http://msysgit.github.io
Mac: brew install git
Ubuntu: apt-get install git
用戶配置:
git config --global user.name "Darcy" git config --global user.name text.example.com
配置級別:
2.git init初始化之后會(huì)出現(xiàn)一個(gè).git/目錄,下面存儲(chǔ)著包括config文件在內(nèi)的幾乎所有g(shù)it相關(guān)文件。
3.git status跟蹤:track
4.git add添加文件內(nèi)容到暫存區(qū),同時(shí)文件被跟蹤。
批量添加: git add . 添加當(dāng)前目錄所有文件
5..gitignore如果有不希望跟蹤的文件,那么需要配置忽略文件。
僅作用于未跟蹤的文件。
gitignore常見配置:github中的示例
6.git rm從暫存區(qū)刪除文件。
git rm --cached 僅僅從暫存區(qū)刪除
git rm 同時(shí)從暫存區(qū)和工作目錄刪除
git rm $(git ls-files --deleted) 刪除所有被跟蹤,但是在工作目錄被刪除的文件
7.git commit提交。
git commit -m "initial commit"
git commit -a -m "initial commit" 直接提交
8.git log提交歷史記錄。
git log
git log --oneline 只有7位hash和提交時(shí)輸入的commit message
git log --color --graph --pretty=format:(此處省略2行) 更美觀,且有分支鏈
上面的命令太長了,不可能每次都這樣輸入,因此需要配置別名alias。
語法:git config --global alias.shortname
例子:git config --global alias.lg "log --color --graph --pretty=format:(此處省略2行)"
這樣就可以用 git lg 來表示上面那行命令了。
別名其實(shí)也存儲(chǔ)在gitcofig文件中
9.git diff顯示版本差異。
git diff 工作目錄與暫存區(qū)的差異
git diff -cached[
git diff [
撤銷本地修改。
即:將工作內(nèi)容從暫存區(qū)復(fù)制到工作目錄。
11.git reset HEAD取消暫存。
即:將文件內(nèi)容從上次提交復(fù)制到暫存區(qū)。
12.git checkout HEAD --撤銷全部改動(dòng):取消暫存 + 撤銷本地修改。
git分支操作 13.git branchgit branch
git branch -d
git branch -v 顯示所有分支信息
14.git checkout通過移動(dòng)HEAD檢出版本,可用于分支切換。
git checkout
git checkout -b
git checkout -b
git checkout - 回到上一個(gè)分支(把HEAD移動(dòng)到上一個(gè)分支)
15.git reset將當(dāng)前分支恢復(fù)到某個(gè)歷史版本。以下三種模式的主要區(qū)別是內(nèi)容是否會(huì)恢復(fù)到工作目錄和暫存區(qū)。
git reset --mixed e33e42 --mixed是默認(rèn)參數(shù),不寫也行,當(dāng)前內(nèi)容(即原來的提交)會(huì)被復(fù)制到暫存區(qū)
git reset --hard e33e42 --hard 時(shí),當(dāng)前內(nèi)容(即原來的提交)會(huì)被復(fù)制到暫存區(qū)和工作目錄
git reset --soft e33e42 --soft時(shí),暫存區(qū)和工作目錄都不會(huì)有任何改變,原來的提交變成了一個(gè)無索引的提交,有可能會(huì)被回收,可以用 git reflog 找回來
捷徑:git reset HEAD^/HEAD~1/HEAD~n HEAD的上一次提交,前第n次提交
區(qū)分reset 與 checkout 在操作分支與操作文件時(shí)的不同 16.git stash我們在git checkout切換分支的時(shí)候,經(jīng)常會(huì)被提示“當(dāng)前有未提交的內(nèi)容,請commit或stash”,而我們通常是寫到一半不希望commit的,所以這時(shí)就需要git stash。
作用是:保存目前的工作目錄和暫存區(qū)狀態(tài),返回一個(gè)干凈的工作空間。
git stash save "push to stash area" 第一步:保存
git stash list 第二步:查看已有列表 會(huì)顯示:stash@{0}: On master: push to stash area
git stash apply stash@{0} 第三步:把保存的內(nèi)容恢復(fù)到工作目錄
git stash drop stash@{0} 第四步:把對應(yīng)的stash命令刪除掉
git stash pop stash@{0} 捷徑:第三步+第四步
17.git merge假定當(dāng)前在master分支。
git merge next 合并 next 分支的內(nèi)容到master分支
如有沖突,會(huì)是下面這樣:
<<<<<<< HEAD next ======= origin/master >>>>>>> origin/master
====上面指當(dāng)前分支的提交,下面是要merge過來的分支的提交內(nèi)容。
18.git rebase修剪提交歷史的基線,俗稱“變基”。
git rebase master
不要在共有分支使用rebase。
19.git tag標(biāo)簽,一個(gè)不變的別名。用于標(biāo)記某次發(fā)布。指向一個(gè)commit對象。
git tag v0.1 e39d0b2
打完標(biāo)簽之后,可以直接使用標(biāo)簽名切換分支: git checkout v0.1
git遠(yuǎn)程操作 20.git push提交本地歷史到遠(yuǎn)程。
21.git remotegit remote add origin ~/git-server 添加一個(gè)遠(yuǎn)程倉庫別名origin
git remote -v 查看遠(yuǎn)程倉庫信息
22.git fetch獲取遠(yuǎn)程倉庫的提交歷史。
git fetch origin/master
git merge origin/master
23.git pullgit pull
=git fetch + git merge
23.git clone獲取一個(gè)遠(yuǎn)程倉庫作為本地倉庫。
git clone ~/git-server test2 會(huì)克隆遠(yuǎn)程倉庫到 test2目錄下
技術(shù)選型 模塊化(JS) 一、模塊 1.模塊的職責(zé):封裝實(shí)現(xiàn)
暴露接口
聲明依賴
2.第一步:沒有應(yīng)用任何模塊系統(tǒng)(反模式 Anti-Pattern)math模塊:
//math.js function add(a, b) { return a + b; } function sub(a, b) { return a - b; }
caculator模塊:
//caculator.js var action = "add"; function compute(a, b){ switch(action){ case "add": return add(a, b); case "sub": return sub(a, b); } }
可以看出 caculator模塊是依賴math模塊的。
math模塊特點(diǎn):無封裝性:變量全部散落在全局里。
接口結(jié)構(gòu)不明顯:如果我們沒有簡化代碼,那么并不能清楚的知道math到底輸出了哪些接口。
caculator模塊特點(diǎn):沒有依賴聲明:依賴了math模塊但是卻沒有聲明。
使用全局狀態(tài):使用了action這個(gè)全局狀態(tài),應(yīng)該盡量避免。
3.第二步:使用字面量(Object Literal)優(yōu)化math模塊:
//math.js var math = { add: function add(a, b) { return a + b; } sub: function sub(a, b) { return a - b; } }
caculator模塊:
//caculator.js var caculator = { action: "add", compute: function compute(a, b){ switch(action){ case "add": return add(a, b); case "sub": return sub(a, b); } } }math模塊特點(diǎn):
結(jié)構(gòu)性好:用字面量把接口進(jìn)行了結(jié)構(gòu)化。
訪問控制差:依然沒有進(jìn)行控制。
caculator模塊特點(diǎn):依然沒有依賴聲明:依賴了math模塊但是卻沒有聲明。
無法設(shè)置私有屬性:action雖然是成員屬性,但在外部依然可以訪問到。
4.第三步:使用立即執(zhí)行的函數(shù)表達(dá)式IIFE(Immediately-invoked Function Expression)解決無法設(shè)置私有屬性的問題。caculator模塊:
//caculator.js var caculator = (function(){ var action = "add"; return { compute: function compute(a, b){ switch(action){ case "add": return math.add(a, b); case "sub": return math.sub(a, b); } } } })();caculator模塊特點(diǎn):
依然依然沒有依賴聲明:依賴了math模塊但是卻沒有聲明。
有了私有屬性:action是我們要的私有屬性,compute函數(shù)可以訪問到,而且在caculator外面無法訪問到。
5.第四步:增加依賴聲明caculator模塊:
//caculator.js var caculator = (function(m){ var action = "add"; function compute(a, b){ switch(action){ case "add": return m.add(a, b); case "sub": return m.sub(a, b); } } return { compute: conpute } })(math);caculator模塊特點(diǎn):
顯示了依賴聲明:把math模塊作為參數(shù)傳了進(jìn)去,并且可以對形參進(jìn)行命名,這里命名為m。
math模塊仍然污染了全局變量。
必須手動(dòng)進(jìn)行依賴管理:math模塊是手動(dòng)傳進(jìn)去的,必須手動(dòng)保證math是在這之前就被加載了。
注意return的部分與原來不一樣了:學(xué)名叫 揭露模塊模式review module pattern,優(yōu)點(diǎn)是在暴露的模塊進(jìn)行增刪查改的時(shí)候會(huì)非常方便。
6.第五步:使用命名空間(name space)解決污染全局空間的問題幫助我們只暴露一個(gè)類似于namespace的全局變量。而不是將math這樣的模塊都注冊在全局作用域中。
math模塊:
//math.js namespace("math", [], function(){ function add(a, b) { return a + b; } function sub(a, b) { return a - b; } return { add: add, sub: sub } }) //第一個(gè)參數(shù)為模塊聲明,第二個(gè)參數(shù)為依賴的模塊,第三個(gè)參數(shù)為模塊的構(gòu)成
caculator模塊:
//caculator.js namespace("caculator", ["math"], function(m){ var action = "add"; function compute(a, b){ return m[action](a, b); } return { compute: compute } }
依賴是統(tǒng)一注冊在某個(gè)地方,而不是全局中的一個(gè)變量。
namespace的實(shí)現(xiàn):
cache中緩存了所有的模塊。
實(shí)際返回的是createModule這個(gè)函數(shù),參數(shù)包括:模塊名,依賴的模塊,當(dāng)前模塊的實(shí)現(xiàn)。
如果只傳入了一個(gè)參數(shù),就返回這個(gè)模塊cache[name]。
取得所有依賴的模塊deps,即保證前面的模塊都已經(jīng)被定義好了,這樣當(dāng)前模塊(這里為caculator模塊)才能運(yùn)行。
最后初始化模并返回定義的模塊cache[name]。
不再污染全局環(huán)境:把模塊都定義在一個(gè)namespace變量中。
沒有依賴管理:依然是我們手動(dòng)進(jìn)行依賴管理。
依賴管理(dependency manage)如果這些模塊分散在不同的文件中,我們在用的時(shí)候就要對引入的腳本順序進(jìn)行手動(dòng)排序。
比如 module2.js中依賴了module1.js,那么寫的時(shí)候就要先寫module.js,像這樣:
但是我們在實(shí)際開發(fā)過程中的依賴總是很復(fù)雜。那是一條又長又復(fù)雜的依賴鏈。非要人肉分析是會(huì)抓狂的。而這其實(shí)是模塊系統(tǒng)的工作。
二、模塊系統(tǒng) 1.模塊系統(tǒng)的職責(zé)依賴管理(加載 / 注入 / 分析 / 初始化)
決定模塊寫法
2.CommonJS//main.js function add(a, b){ return a + b; } function sub(a, b){ return a - b; } exports.add = add exports.sub = sub
比原來的寫法多了接口暴露:exports.add = add exports.sub = sub
//caculator.js var math = require("./math"); function Caculator(container){ //... } exports.Caculator = Caculator
比原來的寫法多了依賴聲明: var math = require("./math"); 和 接口暴露:exports.Caculator = Caculator。
優(yōu)點(diǎn):
運(yùn)行時(shí)支持,模塊定義非常簡單:只是利用了幾個(gè)全局變量exports, module, require。
文件級別的模塊作用域隔離:這幾個(gè)全局變量的作用域都是文件級別的,雖然JS沒有文件級別的作用域,但我們對它進(jìn)行了封裝,使得使用時(shí)一個(gè)文件有一個(gè)作用域,它們使用起來非常安全。
可以處理循環(huán)依賴。
缺點(diǎn):
不是標(biāo)準(zhǔn)組織的規(guī)范。
同步的require,沒有考慮瀏覽器環(huán)境。而我們的瀏覽器文件加載是一個(gè)異步的過程,這是最大的問題,這是否就意味著我們的瀏覽器沒辦法使用了呢?當(dāng)然不是?,F(xiàn)在有很多工具比如browserify,比如webpack,可以幫助我們把多個(gè)文件級別的模塊打包成一個(gè)文件,這樣我們引入單個(gè)文件就可以在瀏覽器里使用了。
因?yàn)镃ommonJS天然的不適合異步環(huán)境,所以出現(xiàn)了天然異步的AMD(Asynchronous Module Definition)
3.AMD與我們前面的namespace非常像。
//main.js define([], function(){ function add(a, b){ return a + b; } function sub(a, b){ return a - b; } return { add: add, sub: sub } })
比原來的寫法多了包裹函數(shù):define,第一個(gè)參數(shù)為依賴的模塊列表,第二個(gè)參數(shù)為當(dāng)前模塊的實(shí)現(xiàn)。
//caculator.js define(["./math"], function(math){ function Caculator(container){ //... } return { Caculator: Caculator } }
同時(shí)AMD還支持一個(gè)簡單的CommonJS寫法,只不過要用一層函數(shù)包裹起來define(function(require, exports){ ... })。
優(yōu)點(diǎn):
專為異步I/O環(huán)境打造,適合瀏覽器環(huán)境。
支持類似CommonJS的書寫方式。
通過插件支持可以加載非JS資源。
成熟的打包構(gòu)建工具,并可結(jié)合插件實(shí)現(xiàn)一些預(yù)處理的工作。
缺點(diǎn):
模塊定義繁瑣,需要額外的函數(shù)嵌套。
只是庫級別的支持,需要引入額外的庫,比如requireJS。
無法處理循環(huán)依賴。
無法實(shí)現(xiàn)條件加載,因?yàn)橹皇菐旒墑e的。
4.原生JS語言級別支持的模塊化標(biāo)準(zhǔn)ES6 Module(Javascript module definition for future)//main.js function add(a, b){ return a + b; } function sub(a, b){ return a - b; } export { add, sub }
比原來的寫法多了接口暴露:export {add, sub}
//caculator.js import { math } from "./math"; function Caculator(container){ //... } export { Caculator }
比原來的寫法多了依賴聲明: import { math } from "./math"; 和 接口暴露:export { Caculator }。
優(yōu)點(diǎn):
真正官方的規(guī)范,未來的趨勢。
語言級別的支持。
適應(yīng)所有的JavaScript運(yùn)行時(shí)環(huán)境,包括瀏覽器。
可以處理循環(huán)依賴。
框架(JS框架) 什么是庫和框架 庫針對特定問題的解答,就有專業(yè)性
不控制應(yīng)用程序的流程
被動(dòng)的被調(diào)用
比如,一個(gè)DatePicker時(shí)間選擇器是一個(gè)庫,一個(gè)Backbone.view是一個(gè)框架。
框架控制反轉(zhuǎn) Inverse of control <···主要區(qū)別
決定應(yīng)用程序生命周期
一般會(huì)集成大量的庫
下面這個(gè)圖很好的解釋了控制反轉(zhuǎn):
框架決定了什么時(shí)候調(diào)用庫,什么時(shí)候要求你的代碼去實(shí)現(xiàn)某些功能。
框架和庫,他們都是解決方案。關(guān)于解決方案,分為7各方面:
DOM
communication 通信
Utility 工具庫
Template 模板技術(shù)
Component 組件
Route 路由
Architecture MV*架構(gòu)
1.DOM解決方案 重點(diǎn):Selector / Manipulation(操作) / Event(dom) / AnimationjQuery
zepto.JS
Mootools
手勢支持:Hammer.js
局部滾動(dòng):iScroll.js
高級動(dòng)畫:Velocity.js
視頻播放:video.js
2.Communication(通信)解決方案 重點(diǎn):XMLHttpRequest / Form / JSONP / Socket 作用:處理與服務(wù)器的請求與響應(yīng)
預(yù)處理請求數(shù)據(jù)/響應(yīng)數(shù)據(jù) & Error/Success的判斷封裝
多種類型請求,統(tǒng)一接口
處理瀏覽器兼容性
jQuery
zepto.JS
Reqwest
qwest
以上都是異步的請求,但對于實(shí)時(shí)性要求非常高的產(chǎn)品比如im聊天工具,就需要立即響應(yīng)。這時(shí)需要用websocket。推薦下面的庫:
socket.io
3.Utility(工具包)解決方案 重點(diǎn):函數(shù)增強(qiáng) & shim / Flow Control 職責(zé):提供JS原生不提供的功能
方法門面包裝,使其易于使用。即shim(語言墊片),保證實(shí)現(xiàn)與規(guī)范一致。
異步隊(duì)列 / 流程控制 比如promise
3.Template 三種類型:String-based / Dom-based / Living Template 4.Component組件 常用組件: Modal / Slider / DatePicker / Tabs / EditorBootstrap
Foundation
5.Routing路由 分類:Client Side / Server Side 職責(zé):監(jiān)聽url變化,并通知注冊的模塊,進(jìn)行頁面切換
通過Javascript進(jìn)行主動(dòng)跳轉(zhuǎn)
歷史管理
對目標(biāo)瀏覽器的兼容性的支持
route庫 6.Architecture架構(gòu)(目的:解耦) 分類:MVC / MVVM / MV* 職責(zé):提供一種范式幫助(強(qiáng)制)開發(fā)者進(jìn)行模塊解耦
試圖與模型分離
更容易進(jìn)行單元測試
更容易實(shí)現(xiàn)應(yīng)用程序的擴(kuò)展
各種框架比較的參考網(wǎng)站:
http://todomvc.com/
https://www.javascripting.com/
https://www.javascriptoo.com/
http://microjs.com/#
數(shù)據(jù)類型(每個(gè)頁面的每個(gè)模塊都要多帶帶定義包含的數(shù)據(jù)類型列表)
模板資源
異步接口(請求方式,請求地址,輸入?yún)?shù),輸出結(jié)果)
頁面摘要
4.工程構(gòu)建項(xiàng)目結(jié)構(gòu)
初始代碼
模擬數(shù)據(jù)
系統(tǒng)實(shí)現(xiàn) 1.組件封裝通用原件(logo,輸入框,圖標(biāo),按鈕,翻頁,復(fù)選框列表,loading)
通用列表(歌單。歌手,收藏的節(jié)目)
復(fù)合組件(比如評論)
浮層彈窗
一個(gè)組件(BannerSlifer)的栗子:
2.邏輯實(shí)現(xiàn) 測試發(fā)布 1.測試聯(lián)調(diào)本地測試
異步測試
對接聯(lián)調(diào)
2.發(fā)布上線打包發(fā)布
優(yōu)化配置
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/91709.html
摘要:那該怎么管理這兩個(gè)不同的項(xiàng)目呢解決子模塊用的的同學(xué)肯定一下子就想到子模塊的知識了。最后,也希望有想法的同學(xué)還有大佬多多留言,給點(diǎn)建議原文地址從零開始做前端架構(gòu)腳手架參考資料官方文檔使用定制前端腳手架別人寫的腳手架文件操作相關(guān)文檔子模塊 前言 相信很多人都用過vue-cli或create-react-app或者類似的腳手架。腳手架方便我們復(fù)制,粘貼,或者clone代碼庫,而且還可以更具用...
摘要:如何構(gòu)建一個(gè)自己的框架為什么我們要去構(gòu)建一個(gè)自己的框架可能絕大多數(shù)的人都會(huì)說市面上已經(jīng)那么多的框架了,還造什么輪子。 showImg(https://segmentfault.com/img/bVNg9F?w=500&h=500); 如何構(gòu)建一個(gè)自己的PHP框架 為什么我們要去構(gòu)建一個(gè)自己的PHP框架?可能絕大多數(shù)的人都會(huì)說市面上已經(jīng)那么多的框架了,還造什么輪子?。我的觀點(diǎn)造輪子不是目...
摘要:簡介前端發(fā)展迅速,開發(fā)者富有的創(chuàng)造力不斷的給前端生態(tài)注入新生命,各種庫框架工程化構(gòu)建工具層出不窮,眼花繚亂,不盲目追求前沿技術(shù),學(xué)習(xí)框架和庫在滿足自己開發(fā)需求的基礎(chǔ)上,然后最好可以對源碼進(jìn)行調(diào)研,了解和深入實(shí)現(xiàn)原理,從中可以獲得更多的收獲隨 showImg(https://segmentfault.com/img/remote/1460000016784101?w=936&h=397)...
某熊的技術(shù)之路指北 ? 當(dāng)我們站在技術(shù)之路的原點(diǎn),未來可能充滿了迷茫,也存在著很多不同的可能;我們可能成為 Web/(大)前端/終端工程師、服務(wù)端架構(gòu)工程師、測試/運(yùn)維/安全工程師等質(zhì)量保障、可用性保障相關(guān)的工程師、大數(shù)據(jù)/云計(jì)算/虛擬化工程師、算法工程師、產(chǎn)品經(jīng)理等等某個(gè)或者某幾個(gè)角色。某熊的技術(shù)之路系列文章/書籍/視頻/代碼即是筆者蹣跚行進(jìn)于這條路上的點(diǎn)滴印記,包含了筆者作為程序員的技術(shù)視野、...
閱讀 1772·2021-10-11 10:59
閱讀 2416·2021-09-30 09:53
閱讀 1780·2021-09-22 15:28
閱讀 2804·2019-08-29 15:29
閱讀 1568·2019-08-29 13:53
閱讀 3217·2019-08-29 12:34
閱讀 2865·2019-08-26 10:16
閱讀 2673·2019-08-23 15:16