摘要:把標(biāo)簽恰好放在之前腳本在下載和執(zhí)行期間會(huì)阻止解析。表示引用資源,替換當(dāng)前元素,用在,,上,是頁(yè)面內(nèi)容不可缺少的一部分。聲明是用來(lái)指示瀏覽器關(guān)于頁(yè)面使用哪個(gè)版本進(jìn)行編寫(xiě)的指令。聲明必須是文檔的第一行,位于標(biāo)簽之前。
項(xiàng)目地址 HTML問(wèn)題 HTML5語(yǔ)義化
什么是語(yǔ)義化?就是用合理、正確的標(biāo)簽來(lái)展示內(nèi)容,比如h1~h6定義標(biāo)題。
好處易于用戶閱讀,樣式丟失的時(shí)候能讓頁(yè)面呈現(xiàn)清晰的結(jié)構(gòu)。
有利于SEO,搜索引擎根據(jù)標(biāo)簽來(lái)確定上下文和各個(gè)關(guān)鍵字的權(quán)重。
方便其他設(shè)備解析,如盲人閱讀器根據(jù)語(yǔ)義渲染網(wǎng)頁(yè)
有利于開(kāi)發(fā)和維護(hù),語(yǔ)義化更具可讀性,代碼更好維護(hù),與CSS3關(guān)系更和諧。
http://www.daqianduan.com/654...
為什么最好把 CSS 的標(biāo)簽放在之間?為什么最好把 JS 的標(biāo)簽恰好放在之前,有例外情況嗎?
把放在中
把標(biāo)簽放在之間是規(guī)范要求的內(nèi)容。此外,這種做法可以讓頁(yè)面逐步呈現(xiàn),提高了用戶體驗(yàn)。將樣式表放在文檔底部附近,會(huì)使許多瀏覽器(包括 Internet Explorer)不能逐步呈現(xiàn)頁(yè)面。一些瀏覽器會(huì)阻止渲染,以避免在頁(yè)面樣式發(fā)生變化時(shí),重新繪制頁(yè)面中的元素。這種做法可以防止呈現(xiàn)給用戶空白的頁(yè)面或沒(méi)有樣式的內(nèi)容。
把標(biāo)簽恰好放在之前
腳本在下載和執(zhí)行期間會(huì)阻止 HTML 解析。把標(biāo)簽放在底部,保證 HTML 首先完成解析,將頁(yè)面盡早呈現(xiàn)給用戶。
例外情況是當(dāng)你的腳本里包含document.write()時(shí)。但是現(xiàn)在,document.write()不推薦使用。同時(shí),將標(biāo)簽放在底部,意味著瀏覽器不能開(kāi)始下載腳本,直到整個(gè)文檔(document)被解析。也許,對(duì)此比較好的做法是,使用defer屬性,放在中。
什么是漸進(jìn)式渲染(progressive rendering)?漸進(jìn)式渲染是用于提高網(wǎng)頁(yè)性能(尤其是提高用戶感知的加載速度),以盡快呈現(xiàn)頁(yè)面的技術(shù)。
在以前互聯(lián)網(wǎng)帶寬較小的時(shí)期,這種技術(shù)更為普遍。如今,移動(dòng)終端的盛行,而移動(dòng)網(wǎng)絡(luò)往往不穩(wěn)定,漸進(jìn)式渲染在現(xiàn)代前端開(kāi)發(fā)中仍然有用武之地。
一些舉例:
圖片懶加載——頁(yè)面上的圖片不會(huì)一次性全部加載。當(dāng)用戶滾動(dòng)頁(yè)面到圖片部分時(shí),JavaScript 將加載并顯示圖像。
確定顯示內(nèi)容的優(yōu)先級(jí)(分層次渲染)——為了盡快將頁(yè)面呈現(xiàn)給用戶,頁(yè)面只包含基本的最少量的 CSS、腳本和內(nèi)容,然后可以使用延遲加載腳本或監(jiān)聽(tīng)DOMContentLoaded/load事件加載其他資源和內(nèi)容。
異步加載 HTML 片段——當(dāng)頁(yè)面通過(guò)后臺(tái)渲染時(shí),把 HTML 拆分,通過(guò)異步請(qǐng)求,分塊發(fā)送給瀏覽器。更多相關(guān)細(xì)節(jié)可以在這里找到。
viewportViewport :字面意思為視圖窗口,在移動(dòng)web開(kāi)發(fā)中使用。表示將設(shè)備瀏覽器寬度虛擬成一個(gè)特定的值(或計(jì)算得出),這樣利于移動(dòng)web站點(diǎn)跨設(shè)備顯示效果基本一致。移動(dòng)版的 Safari 瀏覽器最新引進(jìn)了 viewport 這個(gè) meta tag,讓網(wǎng)頁(yè)開(kāi)發(fā)者來(lái)控制 viewport 的大小和縮放,其他手機(jī)瀏覽器也基本支持。
在移動(dòng)端瀏覽器當(dāng)中,存在著兩種視口,一種是可見(jiàn)視口(也就是我們說(shuō)的設(shè)備大?。?,另一種是視窗視口(網(wǎng)頁(yè)的寬度是多少)。
舉個(gè)例子:如果我們的屏幕是320像素 * 480像素的大小(iPhone4),假設(shè)在瀏覽器中,320像素的屏幕寬度能夠展示980像素寬度的內(nèi)容。那么320像素的寬度就是可見(jiàn)視口的寬度,而能夠顯示的980像素的寬度就是視窗視口的寬度。
為了顯示更多的內(nèi)容,大多數(shù)的瀏覽器會(huì)把自己的視窗視口擴(kuò)大,簡(jiǎn)易的理解,就是讓原本320像素的屏幕寬度能夠容下980像素甚至更寬的內(nèi)容(將網(wǎng)頁(yè)等比例縮小)。
Viewport屬性值width 設(shè)置layout viewport 的寬度,為一個(gè)正整數(shù),或字符串"width-device"
initial-scale 設(shè)置頁(yè)面的初始縮放值,為一個(gè)數(shù)字,可以帶小數(shù)
minimum-scale 允許用戶的最小縮放值,為一個(gè)數(shù)字,可以帶小數(shù)
maximum-scale 允許用戶的最大縮放值,為一個(gè)數(shù)字,可以帶小數(shù)
height 設(shè)置layout viewport 的高度,這個(gè)屬性對(duì)我們并不重要,很少使用
user-scalable 是否允許用戶進(jìn)行縮放,值為"no"或"yes", no 代表不允許,yes代表允許這些屬性可以同時(shí)使用,也可以多帶帶使用或混合使用,多個(gè)屬性同時(shí)使用時(shí)用逗號(hào)隔開(kāi)就行了。
Reflow和Repaint Reflow當(dāng)涉及到DOM節(jié)點(diǎn)的布局屬性發(fā)生變化時(shí),就會(huì)重新計(jì)算該屬性,瀏覽器會(huì)重新描繪相應(yīng)的元素,此過(guò)程叫Reflow(回流或重排)。
Repaint當(dāng)影響DOM元素可見(jiàn)性的屬性發(fā)生變化 (如 color) 時(shí), 瀏覽器會(huì)重新描繪相應(yīng)的元素, 此過(guò)程稱(chēng)為Repaint(重繪)。因此重排必然會(huì)引起重繪。
引起Repaint和Reflow的一些操作調(diào)整窗口大小
字體大小
樣式表變動(dòng)
元素內(nèi)容變化,尤其是輸入控件
CSS偽類(lèi)激活,在用戶交互過(guò)程中發(fā)生
DOM操作,DOM元素增刪、修改
width, clientWidth, scrollTop等布局寬高的計(jì)算
Repaint和Reflow是不可避免的,只能說(shuō)對(duì)性能的影響減到最小,給出下面幾條建議:避免逐條更改樣式。建議集中修改樣式,例如操作className。
避免頻繁操作DOM。創(chuàng)建一個(gè)documentFragment或div,在它上面應(yīng)用所有DOM操作,最后添加到文檔里。設(shè)置display:none的元素上操作,最后顯示出來(lái)。
避免頻繁讀取元素幾何屬性(例如scrollTop)。絕對(duì)定位具有復(fù)雜動(dòng)畫(huà)的元素。
絕對(duì)定位使它脫離文檔流,避免引起父元素及后續(xù)元素大量的回流
https://harttle.land/2015/08/...
http://www.blueidea.com/tech/...
img的alt屬性
如果無(wú)法顯示圖像,瀏覽器將顯示alt指定的內(nèi)容
元素title屬性
在鼠標(biāo)移到元素上時(shí)顯示title的內(nèi)容
href和src區(qū)別href
href標(biāo)識(shí)超文本引用,用在link和a等元素上,href是引用和頁(yè)面關(guān)聯(lián),是在當(dāng)前元素和引用資源之間建立聯(lián)系
若在文檔中添加href ,瀏覽器會(huì)識(shí)別該文檔為 CSS 文件,就會(huì)并行下載資源并且不會(huì)停止對(duì)當(dāng)前文檔的處理。這也是為什么建議使用 link 方式加載 CSS,而不是使用 @import 方式。
src
src表示引用資源,替換當(dāng)前元素,用在img,script,iframe上,src是頁(yè)面內(nèi)容不可缺少的一部分。
當(dāng)瀏覽器解析到src ,會(huì)暫停其他資源的下載和處理(圖片不會(huì)暫停其他資源下載和處理),直到將該資源加載、編譯、執(zhí)行完畢,圖片和框架等也如此,類(lèi)似于將所指向資源應(yīng)用到當(dāng)前內(nèi)容。這也是為什么建議把 js 腳本放在底部而不是頭部的原因。
https://blog.csdn.net/lhjueji...
瀏覽器的渲染過(guò)程解析HTML生成DOM樹(shù)。
解析CSS生成CSSOM規(guī)則樹(shù)。
將DOM樹(shù)與CSSOM規(guī)則樹(shù)合并在一起生成渲染樹(shù)。
遍歷渲染樹(shù)開(kāi)始布局,計(jì)算每個(gè)節(jié)點(diǎn)的位置大小信息。
將渲染樹(shù)每個(gè)節(jié)點(diǎn)繪制到屏幕。
https://baijiahao.baidu.com/s...
為何會(huì)出現(xiàn)瀏覽器兼容問(wèn)題同一產(chǎn)品,版本越老 bug 越多
同一產(chǎn)品,版本越新,功能越多
不同產(chǎn)品,不同標(biāo)準(zhǔn),不同實(shí)現(xiàn)方式
處理兼容問(wèn)題的思路要不要做
產(chǎn)品的角度(產(chǎn)品的受眾、受眾的瀏覽器比例、效果優(yōu)先還是基本功能優(yōu)先)
成本的角度 (有無(wú)必要做某件事)
2.做到什么程度
讓哪些瀏覽器支持哪些效果
3..如何做
根據(jù)兼容需求選擇技術(shù)框架/庫(kù)(jquery)
根據(jù)兼容需求選擇兼容工具(html5shiv.js、respond.js、css reset、normalize.css、Modernizr)
條件注釋、CSS Hack、js 能力檢測(cè)做一些修補(bǔ)
漸進(jìn)增強(qiáng)(progressive enhancement): 針對(duì)低版本瀏覽器進(jìn)行構(gòu)建頁(yè)面,保證最基本的功能,然后再針對(duì)高級(jí)瀏覽器進(jìn)行效果、交互等改進(jìn)和追加功能達(dá)到更好的用戶體驗(yàn)
優(yōu)雅降級(jí) (graceful degradation): 一開(kāi)始就構(gòu)建完整的功能,然后再針對(duì)低版本瀏覽器進(jìn)行兼容。
https://github.com/jirengu/fr...
doctype有什么用doctype是一種標(biāo)準(zhǔn)通用標(biāo)記語(yǔ)言的文檔類(lèi)型聲明,目的是告訴標(biāo)準(zhǔn)通用標(biāo)記語(yǔ)言解析器要使用什么樣的文檔類(lèi)型定義(DTD)來(lái)解析文檔。
聲明是用來(lái)指示web瀏覽器關(guān)于頁(yè)面使用哪個(gè)HTML版本進(jìn)行編寫(xiě)的指令。
聲明必須是HTML文檔的第一行,位于html標(biāo)簽之前。
瀏覽器本身分為兩種模式,一種是標(biāo)準(zhǔn)模式,一種是怪異模式,瀏覽器通過(guò)doctype來(lái)區(qū)分這兩種模式,doctype在html中的作用就是觸發(fā)瀏覽器的標(biāo)準(zhǔn)模式,如果html中省略了doctype,瀏覽器就會(huì)進(jìn)入到Quirks模式的怪異狀態(tài),在這種模式下,有些樣式會(huì)和標(biāo)準(zhǔn)模式存在差異,而html標(biāo)準(zhǔn)和dom標(biāo)準(zhǔn)值規(guī)定了標(biāo)準(zhǔn)模式下的行為,沒(méi)有對(duì)怪異模式做出規(guī)定,因此不同瀏覽器在怪異模式下的處理也是不同的,所以一定要在html開(kāi)頭使用doctype。
行內(nèi)元素和塊級(jí)元素有哪些 行內(nèi)元素一個(gè)行內(nèi)元素只占據(jù)它對(duì)應(yīng)標(biāo)簽的邊框所包含的空間
一般情況下,行內(nèi)元素只能包含數(shù)據(jù)和其他行內(nèi)元素
b, big, i, small, tt abbr, acronym, cite, code, dfn, em, kbd, strong, samp, var a, bdo, br, img, map, object, q, script, span, sub, sup button, input, label, select, textarea塊級(jí)元素
占據(jù)一整行,高度、行高、內(nèi)邊距和外邊距都可以改變,可以容納塊級(jí)標(biāo)簽和其他行內(nèi)標(biāo)簽
header,form,ul,ol,table,article,div,hr,aside,figure,canvas,video,audio,footeriframe框架有那些優(yōu)缺點(diǎn) 優(yōu)點(diǎn):
iframe能夠原封不動(dòng)的把嵌入的網(wǎng)頁(yè)展現(xiàn)出來(lái)。
如果有多個(gè)網(wǎng)頁(yè)引用iframe,那么你只需要修改iframe的內(nèi)容,就可以實(shí)現(xiàn)調(diào)用的每一個(gè)頁(yè)面內(nèi)容的更改,方便快捷。
網(wǎng)頁(yè)如果為了統(tǒng)一風(fēng)格,頭部和版本都是一樣的,就可以寫(xiě)成一個(gè)頁(yè)面,用iframe來(lái)嵌套,可以增加代碼的可重用。
如果遇到加載緩慢的第三方內(nèi)容如圖標(biāo)和廣告,這些問(wèn)題可以由iframe來(lái)解決。
缺點(diǎn):搜索引擎的爬蟲(chóng)程序無(wú)法解讀這種頁(yè)面
框架結(jié)構(gòu)中出現(xiàn)各種滾動(dòng)條
使用框架結(jié)構(gòu)時(shí),保證設(shè)置正確的導(dǎo)航鏈接。
iframe頁(yè)面會(huì)增加服務(wù)器的http請(qǐng)求
label標(biāo)簽有什么作用label 標(biāo)簽通常是寫(xiě)在表單內(nèi),它關(guān)聯(lián)一個(gè)控件,使用 label 可以實(shí)現(xiàn)點(diǎn)擊文字選取對(duì)應(yīng)的控件。
HTML5的form如何關(guān)閉自動(dòng)完成功能
將不想要自動(dòng)完成的 form 或 input 設(shè)置為 autocomplete=off
MDN
DOM和BOM有什么區(qū)別DOM
Document Object Model,文檔對(duì)象模型
DOM 是為了操作文檔出現(xiàn)的 API,document 是其的一個(gè)對(duì)象
DOM和文檔有關(guān),這里的文檔指的是網(wǎng)頁(yè),也就是html文檔。DOM和瀏覽器無(wú)關(guān),他關(guān)注的是網(wǎng)頁(yè)本身的內(nèi)容。
BOM
Browser Object Model,瀏覽器對(duì)象模型
BOM 是為了操作瀏覽器出現(xiàn)的 API,window 是其的一個(gè)對(duì)象
window 對(duì)象既為 javascript 訪問(wèn)瀏覽器提供API,同時(shí)在 ECMAScript 中充當(dāng) Global 對(duì)象
瀏覽器通過(guò)優(yōu)先級(jí)規(guī)則,判斷元素展示哪些樣式。優(yōu)先級(jí)通過(guò) 4 個(gè)維度指標(biāo)確定,我們假定以a、b、c、d命名,分別代表以下含義:
a表示是否使用內(nèi)聯(lián)樣式(inline style)。如果使用,a為 1,否則為 0。
b表示 ID 選擇器的數(shù)量。
c表示類(lèi)選擇器、屬性選擇器和偽類(lèi)選擇器數(shù)量之和。
d表示標(biāo)簽(類(lèi)型)選擇器和偽元素選擇器之和。
優(yōu)先級(jí)的結(jié)果并非通過(guò)以上四個(gè)值生成一個(gè)得分,而是每個(gè)值分開(kāi)比較。a、b、c、d權(quán)重從左到右,依次減小。判斷優(yōu)先級(jí)時(shí),從左到右,一一比較,直到比較出最大值,即可停止。所以,如果b的值不同,那么c和d不管多大,都不會(huì)對(duì)結(jié)果產(chǎn)生影響。比如0,1,0,0的優(yōu)先級(jí)高于0,0,10,10。
當(dāng)出現(xiàn)優(yōu)先級(jí)相等的情況時(shí),最晚出現(xiàn)的樣式規(guī)則會(huì)被采納。如果你在樣式表里寫(xiě)了相同的規(guī)則(無(wú)論是在該文件內(nèi)部還是其它樣式文件中),那么最后出現(xiàn)的(在文件底部的)樣式優(yōu)先級(jí)更高,因此會(huì)被采納。
在寫(xiě)樣式時(shí),我會(huì)使用較低的優(yōu)先級(jí),這樣這些樣式可以輕易地覆蓋掉。尤其對(duì)寫(xiě) UI 組件的時(shí)候更為重要,這樣使用者就不需要通過(guò)非常復(fù)雜的優(yōu)先級(jí)規(guī)則或使用!important的方式,去覆蓋組件的樣式了。
https://www.smashingmagazine....
https://www.sitepoint.com/web...
重置(resetting)CSS 和 標(biāo)準(zhǔn)化(normalizing)CSS 的區(qū)別是什么?你會(huì)選擇哪種方式,為什么?重置(Resetting): 重置意味著除去所有的瀏覽器默認(rèn)樣式。對(duì)于頁(yè)面所有的元素,像margin、padding、font-size這些樣式全部置成一樣。你將必須重新定義各種元素的樣式。
標(biāo)準(zhǔn)化(Normalizing): 標(biāo)準(zhǔn)化沒(méi)有去掉所有的默認(rèn)樣式,而是保留了有用的一部分,同時(shí)還糾正了一些常見(jiàn)錯(cuò)誤。
當(dāng)需要實(shí)現(xiàn)非常個(gè)性化的網(wǎng)頁(yè)設(shè)計(jì)時(shí),我會(huì)選擇重置的方式,因?yàn)槲乙獙?xiě)很多自定義的樣式以滿足設(shè)計(jì)需求,這時(shí)候就不再需要標(biāo)準(zhǔn)化的默認(rèn)樣式了。
https://stackoverflow.com/que...
請(qǐng)闡述Float定位的工作原理。浮動(dòng)(float)是 CSS 定位屬性。浮動(dòng)元素從網(wǎng)頁(yè)的正常流動(dòng)中移出,但是保持了部分的流動(dòng)性,會(huì)影響其他元素的定位(比如文字會(huì)圍繞著浮動(dòng)元素)。這一點(diǎn)與絕對(duì)定位不同,絕對(duì)定位的元素完全從文檔流中脫離。
CSS 的clear屬性通過(guò)使用left、right、both,讓該元素向下移動(dòng)(清除浮動(dòng))到浮動(dòng)元素下面。
如果父元素只包含浮動(dòng)元素,那么該父元素的高度將塌縮為 0。我們可以通過(guò)清除(clear)從浮動(dòng)元素后到父元素關(guān)閉前之間的浮動(dòng)來(lái)修復(fù)這個(gè)問(wèn)題。
有一種 hack 的方法,是自定義一個(gè).clearfix類(lèi),利用偽元素選擇器::after清除浮動(dòng)。另外還有一些方法,比如添加空的和設(shè)置浮動(dòng)元素父元素的overflow屬性。與這些方法不同的是,clearfix方法,只需要給父元素添加一個(gè)類(lèi),定義如下:
.clearfix::after { content: ""; display: block; clear: both; }
值得一提的是,把父元素屬性設(shè)置為overflow: auto或overflow: hidden,會(huì)使其內(nèi)部的子元素形成塊格式化上下文(Block Formatting Context),并且父元素會(huì)擴(kuò)張自己,使其能夠包圍它的子元素。
https://css-tricks.com/all-ab...
請(qǐng)闡述z-index屬性,并說(shuō)明如何形成層疊上下文(stacking context)。CSS 中的z-index屬性控制重疊元素的垂直疊加順序。z-index只能影響position值不是static的元素。
沒(méi)有定義z-index的值時(shí),元素按照它們出現(xiàn)在 DOM 中的順序堆疊(層級(jí)越低,出現(xiàn)位置越靠上)。非靜態(tài)定位的元素(及其子元素)將始終覆蓋靜態(tài)定位(static)的元素,而不管 HTML 層次結(jié)構(gòu)如何。
層疊上下文是包含一組圖層的元素。 在一組層疊上下文中,其子元素的z-index值是相對(duì)于該父元素而不是 document root 設(shè)置的。每個(gè)層疊上下文完全獨(dú)立于它的兄弟元素。如果元素 B 位于元素 A 之上,則即使元素 A 的子元素 C 具有比元素 B 更高的z-index值,元素 C 也永遠(yuǎn)不會(huì)在元素 B 之上.
每個(gè)層疊上下文是自包含的:當(dāng)元素的內(nèi)容發(fā)生層疊后,整個(gè)該元素將會(huì)在父層疊上下文中按順序進(jìn)行層疊。少數(shù) CSS 屬性會(huì)觸發(fā)一個(gè)新的層疊上下文,例如opacity小于 1,filter不是none,transform不是none。
https://css-tricks.com/almana...
https://philipwalton.com/arti...
https://developer.mozilla.org...
請(qǐng)闡述塊格式化上下文(Block Formatting Context)及其工作原理。塊格式上下文(BFC)是 Web 頁(yè)面的可視化 CSS 渲染的部分,是塊級(jí)盒布局發(fā)生的區(qū)域,也是浮動(dòng)元素與其他元素交互的區(qū)域。
一個(gè) HTML 盒(Box)滿足以下任意一條,會(huì)創(chuàng)建塊格式化上下文:
float的值不是none.
position的值不是static或relative.
display的值是table-cell、table-caption、inline-block、flex、或inline-flex。
overflow的值不是visible。
在 BFC 中,每個(gè)盒的左外邊緣都與其包含的塊的左邊緣相接。
兩個(gè)相鄰的塊級(jí)盒在垂直方向上的邊距會(huì)發(fā)生合并(collapse)。更多內(nèi)容請(qǐng)參考邊距合并(margin collapsing)。
https://developer.mozilla.org...
https://www.sitepoint.com/und...
有哪些清除浮動(dòng)的技術(shù),都適用哪些情況?空div方法:。
Clearfix 方法:上文使用.clearfix類(lèi)已經(jīng)提到。
overflow: auto或overflow: hidden方法:上文已經(jīng)提到。
在大型項(xiàng)目中,我會(huì)使用 Clearfix 方法,在需要的地方使用.clearfix。設(shè)置overflow: hidden的方法可能使其子元素顯示不完整,當(dāng)子元素的高度大于父元素時(shí)。
請(qǐng)解釋什么是雪碧圖(css sprites),以及如何實(shí)現(xiàn)?雪碧圖是把多張圖片整合到一張上的圖片。它被運(yùn)用在眾多使用了很多小圖標(biāo)的網(wǎng)站上(Gmail 在使用)。實(shí)現(xiàn)方法:
使用生成器將多張圖片打包成一張雪碧圖,并為其生成合適的 CSS。
每張圖片都有相應(yīng)的 CSS 類(lèi),該類(lèi)定義了background-image、background-position和background-size屬性。
使用圖片時(shí),將相應(yīng)的類(lèi)添加到你的元素中。
好處:
減少加載多張圖片的 HTTP 請(qǐng)求數(shù)(一張雪碧圖只需要一個(gè)請(qǐng)求)。但是對(duì)于 HTTP2 而言,加載多張圖片不再是問(wèn)題。
提前加載資源,防止在需要時(shí)才在開(kāi)始下載引發(fā)的問(wèn)題,比如只出現(xiàn)在:hover偽類(lèi)中的圖片,不會(huì)出現(xiàn)閃爍。
https://css-tricks.com/css-sp...
如何解決不同瀏覽器的樣式兼容性問(wèn)題?在確定問(wèn)題原因和有問(wèn)題的瀏覽器后,使用多帶帶的樣式表,僅供出現(xiàn)問(wèn)題的瀏覽器加載。這種方法需要使用服務(wù)器端渲染。
使用已經(jīng)處理好此類(lèi)問(wèn)題的庫(kù),比如 Bootstrap。
使用 autoprefixer 自動(dòng)生成 CSS 屬性前綴。
使用 Reset CSS 或 Normalize.css。
如何為功能受限的瀏覽器提供頁(yè)面? 使用什么樣的技術(shù)和流程?優(yōu)雅的降級(jí):為現(xiàn)代瀏覽器構(gòu)建應(yīng)用,同時(shí)確保它在舊版瀏覽器中正常運(yùn)行。
Progressive enhancement - The practice of building an application for a base level of user experience, but adding functional enhancements when a browser supports it.
漸進(jìn)式增強(qiáng):構(gòu)建基于用戶體驗(yàn)的應(yīng)用,但在瀏覽器支持時(shí)添加新增功能。
利用 caniuse.com 檢查特性支持。
使用 autoprefixer 自動(dòng)生成 CSS 屬性前綴。
使用 Modernizr進(jìn)行特性檢測(cè)。
有什么不同的方式可以隱藏內(nèi)容(使其僅適用于屏幕閱讀器)?這些方法與可訪問(wèn)性(a11y)有關(guān)。
visibility: hidden:元素仍然在頁(yè)面流中,并占用空間。
width: 0; height: 0:使元素不占用屏幕上的任何空間,導(dǎo)致不顯示它。
position: absolute; left: -99999px: 將它置于屏幕之外。
text-indent: -9999px:這只適用于block元素中的文本。
Metadata: 例如通過(guò)使用 Schema.org,RDF 和 JSON-LD。
WAI-ARIA:如何增加網(wǎng)頁(yè)可訪問(wèn)性的 W3C 技術(shù)規(guī)范。
即使 WAI-ARIA 是理想的解決方案,我也會(huì)采用絕對(duì)定位方法,因?yàn)樗哂凶钌俚淖⒁馐马?xiàng),適用于大多數(shù)元素,而且使用起來(lái)非常簡(jiǎn)單。
https://www.w3.org/TR/wai-ari...
https://developer.mozilla.org...
http://a11yproject.com/
除了screen,你還能說(shuō)出一個(gè) @media 屬性的例子嗎?all
適用于所有設(shè)備。
print
為了加載合適的文檔到當(dāng)前使用的可視窗口. 需要提前咨詢 paged media(媒體屏幕尺寸), 以滿足個(gè)別設(shè)備網(wǎng)頁(yè)尺寸不匹配等問(wèn)題。
screen
主要適用于彩色的電腦屏幕
speech
解析speech這個(gè)合成器. 注意: CSS2已經(jīng)有一個(gè)相似的媒體類(lèi)型叫aural.
https://developer.mozilla.org...
首先,瀏覽器從最右邊的選擇器,即關(guān)鍵選擇器(key selector),向左依次匹配。根據(jù)關(guān)鍵選擇器,瀏覽器從 DOM 中篩選出元素,然后向上遍歷被選元素的父元素,判斷是否匹配。選擇器匹配語(yǔ)句鏈越短,瀏覽器的匹配速度越快。避免使用標(biāo)簽和通用選擇器作為關(guān)鍵選擇器,因?yàn)樗鼈儠?huì)匹配大量的元素,瀏覽器必須要進(jìn)行大量的工作,去判斷這些元素的父元素們是否匹配。
BEM (Block Element Modifier) methodology recommends that everything has a single class, and, where you need hierarchy, that gets baked into the name of the class as well, this naturally makes the selector efficient and easy to override.
BEM (Block Element Modifier)原則上建議為獨(dú)立的 CSS 類(lèi)命名,并且在需要層級(jí)關(guān)系時(shí),將關(guān)系也體現(xiàn)在命名中,這自然會(huì)使選擇器高效且易于覆蓋。
搞清楚哪些 CSS 屬性會(huì)觸發(fā)重新布局(reflow)、重繪(repaint)和合成(compositing)。在寫(xiě)樣式時(shí),避免觸發(fā)重新布局的可能。
https://developers.google.com...
https://csstriggers.com/
使用 CSS 預(yù)處理的優(yōu)缺點(diǎn)分別是什么?優(yōu)點(diǎn):
提高 CSS 可維護(hù)性。
易于編寫(xiě)嵌套選擇器。
引入變量,增添主題功能??梢栽诓煌捻?xiàng)目中共享主題文件。
通過(guò)混合(Mixins)生成重復(fù)的 CSS。
Splitting your code into multiple files. CSS files can be split up too but doing so will require a HTTP request to download each CSS file.
將代碼分割成多個(gè)文件。不進(jìn)行預(yù)處理的 CSS,雖然也可以分割成多個(gè)文件,但需要建立多個(gè) HTTP 請(qǐng)求加載這些文件。
缺點(diǎn):
需要預(yù)處理工具。
重新編譯的時(shí)間可能會(huì)很慢。
對(duì)于你使用過(guò)的 CSS 預(yù)處理,說(shuō)說(shuō)喜歡和不喜歡的地方?喜歡:
絕大部分優(yōu)點(diǎn)上題以及提過(guò)。
Less 用 JavaScript 實(shí)現(xiàn),與 NodeJS 高度結(jié)合。
Dislikes:
我通過(guò)node-sass使用 Sass,它用 C ++ 編寫(xiě)的 LibSass 綁定。在 Node 版本切換時(shí),我必須經(jīng)常重新編譯。
Less 中,變量名稱(chēng)以@作為前綴,容易與 CSS 關(guān)鍵字混淆,如@media、@import和@font-face。
如何實(shí)現(xiàn)一個(gè)使用非標(biāo)準(zhǔn)字體的網(wǎng)頁(yè)設(shè)計(jì)?使用@font-face并為不同的font-weight定義font-family。
解釋瀏覽器如何確定哪些元素與 CSS 選擇器匹配。這部分與上面關(guān)于編寫(xiě)高效的 CSS 有關(guān)。瀏覽器從最右邊的選擇器(關(guān)鍵選擇器)根據(jù)關(guān)鍵選擇器,瀏覽器從 DOM 中篩選出元素,然后向上遍歷被選元素的父元素,判斷是否匹配。選擇器匹配語(yǔ)句鏈越短,瀏覽器的匹配速度越快。
例如,對(duì)于形如p span的選擇器,瀏覽器首先找到所有元素,并遍歷它的父元素直到根元素以找到
元素。對(duì)于特定的,只要找到一個(gè)
,就知道"`已經(jīng)匹配并停止繼續(xù)匹配。
https://stackoverflow.com/que...
描述偽元素及其用途。CSS 偽元素是添加到選擇器的關(guān)鍵字,去選擇元素的特定部分。它們可以用于裝飾(:first-line,:first-letter)或?qū)⒃靥砑拥綐?biāo)記中(與 content:...組合),而不必修改標(biāo)記(:before,:after)。
:first-line和:first-letter可以用來(lái)修飾文字。
上面提到的.clearfix方法中,使用clear: both來(lái)添加不占空間的元素。
使用:before和after展示提示中的三角箭頭。鼓勵(lì)關(guān)注點(diǎn)分離,因?yàn)槿潜灰暈闃邮降囊徊糠?,而不是真正?DOM。如果不使用額外的 HTML 元素,只用 CSS 樣式繪制三角形是不太可能的。
https://css-tricks.com/almana...
說(shuō)說(shuō)你對(duì)盒模型的理解,以及如何告知瀏覽器使用不同的盒模型渲染布局。CSS 盒模型描述了以文檔樹(shù)中的元素而生成的矩形框,并根據(jù)排版模式進(jìn)行布局。每個(gè)盒子都有一個(gè)內(nèi)容區(qū)域(例如文本,圖像等)以及周?chē)蛇x的padding、border和margin區(qū)域。
CSS 盒模型負(fù)責(zé)計(jì)算:
塊級(jí)元素占用多少空間。
邊框是否重疊,邊距是否合并。
盒子的尺寸。
盒模型有以下規(guī)則:
塊級(jí)元素的大小由width、height、padding、border和margin決定。
如果沒(méi)有指定height,則塊級(jí)元素的高度等于其包含子元素的內(nèi)容高度加上padding(除非有浮動(dòng)元素,請(qǐng)參閱下文)。
如果沒(méi)有指定width,則非浮動(dòng)塊級(jí)元素的寬度等于其父元素的寬度減去父元素的padding。
元素的height是由內(nèi)容的height來(lái)計(jì)算的。
元素的width是由內(nèi)容的width來(lái)計(jì)算的。
默認(rèn)情況下,padding和border不是元素width和height的組成部分。
https://www.smashingmagazine....
* { box-sizing: border-box; }會(huì)產(chǎn)生怎樣的效果?元素默認(rèn)應(yīng)用了box-sizing: content-box,元素的寬高只會(huì)決定內(nèi)容(content)的大小。
box-sizing: border-box改變計(jì)算元素width和height的方式,border和padding的大小也將計(jì)算在內(nèi)。
元素的height = 內(nèi)容(content)的高度 + 垂直方向的padding + 垂直方向border的寬度
元素的width = 內(nèi)容(content)的寬度 + 水平方向的padding + 水平方向border的寬度
display的屬性值都有哪些?none, block, inline, inline-block, table, table-row, table-cell, list-item.
inline和inline-block有什么區(qū)別?我把block也加入其中,為了獲得更好的比較。
block | inline-block | inline | |
---|---|---|---|
大小 | 填充其父容器的寬度。 | 取決于內(nèi)容。 | 取決于內(nèi)容。 |
定位 | 從新的一行開(kāi)始,并且不允許旁邊有 HTML 元素(除非是float) | 與其他內(nèi)容一起流動(dòng),并允許旁邊有其他元素。 | 與其他內(nèi)容一起流動(dòng),并允許旁邊有其他元素。 |
能否設(shè)置width和height | 能 | 能 | 不能。 設(shè)置會(huì)被忽略。 |
可以使用vertical-align對(duì)齊 | 不可以 | 可以 | 可以 |
邊距(margin)和填充(padding) | 各個(gè)方向都存在 | 各個(gè)方向都存在 | 只有水平方向存在。垂直方向會(huì)被忽略。 盡管border和padding在content周?chē)?,但垂直方向上的空間取決于"line-height" |
浮動(dòng)(float) | - | - | 就像一個(gè)block元素,可以設(shè)置垂直邊距和填充。 |
經(jīng)過(guò)定位的元素,其position屬性值必然是relative、absolute、fixed或sticky。
static:默認(rèn)定位屬性值。該關(guān)鍵字指定元素使用正常的布局行為,即元素在文檔常規(guī)流中當(dāng)前的布局位置。此時(shí) top, right, bottom, left 和 z-index 屬性無(wú)效。
relative:該關(guān)鍵字下,元素先放置在未添加定位時(shí)的位置,再在不改變頁(yè)面布局的前提下調(diào)整元素位置(因此會(huì)在此元素未添加定位時(shí)所在位置留下空白)。
absolute:不為元素預(yù)留空間,通過(guò)指定元素相對(duì)于最近的非 static 定位祖先元素的偏移,來(lái)確定元素位置。絕對(duì)定位的元素可以設(shè)置外邊距(margins),且不會(huì)與其他邊距合并。
fixed:不為元素預(yù)留空間,而是通過(guò)指定元素相對(duì)于屏幕視口(viewport)的位置來(lái)指定元素位置。元素的位置在屏幕滾動(dòng)時(shí)不會(huì)改變。打印時(shí),元素會(huì)出現(xiàn)在的每頁(yè)的固定位置。fixed 屬性會(huì)創(chuàng)建新的層疊上下文。當(dāng)元素祖先的 transform 屬性非 none 時(shí),容器由視口改為該祖先。
sticky:盒位置根據(jù)正常流計(jì)算(這稱(chēng)為正常流動(dòng)中的位置),然后相對(duì)于該元素在流中的 flow root(BFC)和 containing block(最近的塊級(jí)祖先元素)定位。在所有情況下(即便被定位元素為 table 時(shí)),該元素定位均不對(duì)后續(xù)元素造成影響。當(dāng)元素 B 被粘性定位時(shí),后續(xù)元素的位置仍按照 B 未定位時(shí)的位置來(lái)確定。position: sticky 對(duì) table 元素的效果與 position: relative 相同。
https://developer.mozilla.org...
你使用過(guò)哪些現(xiàn)有的 CSS 框架?你是如何改進(jìn)它們的?Bootstrap: 更新周期緩慢。Bootstrap 4 已經(jīng)處于 alpha 版本將近兩年了。添加了在頁(yè)面中廣泛使用的微調(diào)按鈕組件。
Semantic UI:源代碼結(jié)構(gòu)使得自定義主題很難理解。非常規(guī)主題系統(tǒng)的使用體驗(yàn)很差。外部庫(kù)的路徑需要硬編碼(hard code)配置。變量重新賦值沒(méi)有 Bootstrap 設(shè)計(jì)得好。
Bulma: 需要很多非語(yǔ)義的類(lèi)和標(biāo)記,顯得很多余。不向后兼容,以至于升級(jí)版本后,會(huì)破壞應(yīng)用的正常運(yùn)行。
你了解 CSS Flex 和 Grid 嗎?Flex 主要用于一維布局,而 Grid 則用于二維布局。
Flexflex容器中存在兩條軸, 橫軸和縱軸, 容器中的每個(gè)單元稱(chēng)為flex item。
在容器上可以設(shè)置6個(gè)屬性:
flex-direction
flex-wrap
flex-flow
justify-content
align-items
align-content
注意:當(dāng)設(shè)置 flex 布局之后,子元素的 float、clear、vertical-align 的屬性將會(huì)失效。
Flex 項(xiàng)目屬性有六種屬性可運(yùn)用在 item 項(xiàng)目上:
order
flex-basis
flex-grow
flex-shrink
flex
align-self
GridCSS網(wǎng)格布局用于將頁(yè)面分割成數(shù)個(gè)主要區(qū)域,或者用來(lái)定義組件內(nèi)部元素間大小、位置和圖層之間的關(guān)系。
像表格一樣,網(wǎng)格布局讓我們能夠按行或列來(lái)對(duì)齊元素。 但是,使用CSS網(wǎng)格可能還是比CSS表格更容易布局。 例如,網(wǎng)格容器的子元素可以自己定位,以便它們像CSS定位的元素一樣,真正的有重疊和層次。
響應(yīng)式設(shè)計(jì)與自適應(yīng)設(shè)計(jì)有何不同?響應(yīng)式設(shè)計(jì)和自適應(yīng)設(shè)計(jì)都以提高不同設(shè)備間的用戶體驗(yàn)為目標(biāo),根據(jù)視窗大小、分辨率、使用環(huán)境和控制方式等參數(shù)進(jìn)行優(yōu)化調(diào)整。
響應(yīng)式設(shè)計(jì)的適應(yīng)性原則:網(wǎng)站應(yīng)該憑借一份代碼,在各種設(shè)備上都有良好的顯示和使用效果。響應(yīng)式網(wǎng)站通過(guò)使用媒體查詢,自適應(yīng)柵格和響應(yīng)式圖片,基于多種因素進(jìn)行變化,創(chuàng)造出優(yōu)良的用戶體驗(yàn)。就像一個(gè)球通過(guò)膨脹和收縮,來(lái)適應(yīng)不同大小的籃圈。
自適應(yīng)設(shè)計(jì)更像是漸進(jìn)式增強(qiáng)的現(xiàn)代解釋。與響應(yīng)式設(shè)計(jì)單一地去適配不同,自適應(yīng)設(shè)計(jì)通過(guò)檢測(cè)設(shè)備和其他特征,從早已定義好的一系列視窗大小和其他特性中,選出最恰當(dāng)?shù)墓δ芎筒季?。與使用一個(gè)球去穿過(guò)各種的籃筐不同,自適應(yīng)設(shè)計(jì)允許使用多個(gè)球,然后根據(jù)不同的籃筐大小,去選擇最合適的一個(gè)。
https://developer.mozilla.org...
http://mediumwell.com/respons...
https://css-tricks.com/the-di...
你有沒(méi)有使用過(guò)視網(wǎng)膜分辨率的圖形?當(dāng)中使用什么技術(shù)?我傾向于使用更高分辨率的圖形(顯示尺寸的兩倍)來(lái)處理視網(wǎng)膜顯示。更好的方法是使用媒體查詢,像@media only screen and (min-device-pixel-ratio: 2) { ... },然后改變background-image。
對(duì)于圖標(biāo)類(lèi)的圖形,我會(huì)盡可能使用 svg 和圖標(biāo)字體,因?yàn)樗鼈冊(cè)谌魏畏直媛氏?,都能被渲染得十分清晰?/p>
還有一種方法是,在檢查了window.devicePixelRatio的值后,利用 JavaScript 將 btn.onclick = function() {} btn.onclick = null
DOM2
DOM2級(jí)事件可以冒泡和捕獲
通過(guò)addEventListener綁定
通過(guò)removeEventListener解綁
// 綁定 btn.addEventListener("click", sayHi) // 解綁 btn.removeEventListener("click", sayHi)
DOM3
DOM3具有更多事件類(lèi)型
DOM3級(jí)事件在DOM2級(jí)事件的基礎(chǔ)上添加了更多的事件類(lèi)型,全部類(lèi)型如下:
UI事件,當(dāng)用戶與頁(yè)面上的元素交互時(shí)觸發(fā),如:load、scroll 焦點(diǎn)事件,當(dāng)元素獲得或失去焦點(diǎn)時(shí)觸發(fā),如:blur、focus 鼠標(biāo)事件,當(dāng)用戶通過(guò)鼠標(biāo)在頁(yè)面執(zhí)行操作時(shí)觸發(fā)如:dbclick、mouseup 滾輪事件,當(dāng)使用鼠標(biāo)滾輪或類(lèi)似設(shè)備時(shí)觸發(fā),如:mousewheel 文本事件,當(dāng)在文檔中輸入文本時(shí)觸發(fā),如:textInput 鍵盤(pán)事件,當(dāng)用戶通過(guò)鍵盤(pán)在頁(yè)面上執(zhí)行操作時(shí)觸發(fā),如:keydown、keypress 合成事件,當(dāng)為IME(輸入法編輯器)輸入字符時(shí)觸發(fā),如:compositionstart 變動(dòng)事件,當(dāng)?shù)讓覦OM結(jié)構(gòu)發(fā)生變化時(shí)觸發(fā),如:DOMsubtreeModified
https://www.jianshu.com/p/3ac...
如何自定義事件原生提供了3個(gè)方法實(shí)現(xiàn)自定義事件
createEvent,設(shè)置事件類(lèi)型,是 html 事件還是 鼠標(biāo)事件
initEvent 初始化事件,事件名稱(chēng),是否允許冒泡,是否阻止自定義事件
dispatchEvent 觸發(fā)事件
MDN
target和currentTarget區(qū)別event.target
返回觸發(fā)事件的元素
event.currentTarget
返回綁定事件的元素
prototype和__proto__的關(guān)系是什么所有的對(duì)象都擁有__proto__屬性,它指向?qū)ο髽?gòu)造函數(shù)的prototype屬性
let obj = {} obj.__proto__ === Object.prototype // true function Test(){} test.__proto__ == Test.prototype // true
所有的函數(shù)都同時(shí)擁有__proto__和protytpe屬性
函數(shù)的__proto__指向自己的函數(shù)實(shí)現(xiàn) 函數(shù)的protytpe是一個(gè)對(duì)象 所以函數(shù)的prototype也有__proto__屬性 指向Object.prototype
function func() {} func.prototype.__proto__ === Object.prototype // true
Object.prototype.__proto__指向null
Object.prototype.__proto__ // null原型繼承
所有的JS對(duì)象都有一個(gè)prototype屬性,指向它的原型對(duì)象。當(dāng)試圖訪問(wèn)一個(gè)對(duì)象的屬性時(shí),如果沒(méi)有在該對(duì)象上找到,它還會(huì)搜尋該對(duì)象的原型,以及該對(duì)象的原型的原型,依次層層向上搜索,直到找到一個(gè)名字匹配的屬性或到達(dá)原型鏈的末尾。
繼承JS高程第3版 第6章 繼承
寄生組合式繼承
function SuperType(name) { this.name = name this.colors = ["red"] } SuperType.prototype.sayName = function() { console.log(this.name) } // 繼承實(shí)例屬性 function SubType(name, age) { SuperType.call(this, name) this.age = age } function inheritPrototype(subType, superType) { let prototype = Object.create(superType.prototype) prototype.constructor = subType subType.prototype = prototype } // 繼承原型方法 inheritPrototype(SubType, SuperType) // 定義自己的原型方法 SubType.prototype.sayAge = function() { console.log(this.age) }閉包
閉包是指有權(quán)訪問(wèn)另一個(gè)函數(shù)作用域中的變量的函數(shù)。
function sayHi(name) { return () => { console.log(`Hi! ${name}`) } } const test = sayHi("xiaoming") test() // Hi! xiaoming
雖然sayHi函數(shù)已經(jīng)執(zhí)行完畢,但是其活動(dòng)對(duì)象也不會(huì)被銷(xiāo)毀,因?yàn)閠est函數(shù)仍然引用著sayHi函數(shù)中的變量name,這就是閉包。
但也因?yàn)殚]包引用著另一個(gè)函數(shù)的變量,導(dǎo)致另一個(gè)函數(shù)已經(jīng)不使用了也無(wú)法銷(xiāo)毀,所以閉包使用過(guò)多,會(huì)占用較多的內(nèi)存,這也是一個(gè)副作用。
這個(gè)題目是考察閉包的使用
function sayHi() { console.log("hi") } function threeTimes(fn) { let times = 0 return () => { if (times++ < 3) { fn() } } } const newFn = threeTimes(sayHi) newFn() newFn() newFn() newFn() newFn() // 后面兩次執(zhí)行都無(wú)任何反應(yīng)
通過(guò)閉包變量 times 來(lái)控制函數(shù)的執(zhí)行
實(shí)現(xiàn)add函數(shù),讓add(a)(b)和add(a,b)兩種調(diào)用結(jié)果相同function add(a, b) { if (b === undefined) { return function(x) { return a + x } } return a + b }Ajax
Ajax(asynchronous JavaScript and XML)是使用客戶端上的許多 Web 技術(shù),創(chuàng)建異步 Web 應(yīng)用的一種 Web 開(kāi)發(fā)技術(shù)。借助 Ajax,Web 應(yīng)用可以異步(在后臺(tái))向服務(wù)器發(fā)送數(shù)據(jù)和從服務(wù)器檢索數(shù)據(jù),而不會(huì)干擾現(xiàn)有頁(yè)面的顯示和行為。通過(guò)將數(shù)據(jù)交換層與表示層分離,Ajax 允許網(wǎng)頁(yè)和擴(kuò)展 Web 應(yīng)用程序動(dòng)態(tài)更改內(nèi)容,而無(wú)需重新加載整個(gè)頁(yè)面。實(shí)際上,現(xiàn)在通常將 JSON 替換為 XML,因?yàn)?JavaScript 對(duì) JSON 有原生支持優(yōu)勢(shì)。
XMLHttpRequest API 經(jīng)常用于異步通信。此外還有最近流行的fetch API。
let xmlhttp if (window.XMLHttpRequest) { // IE7+, Firefox, Chrome, Opera, Safari 瀏覽器執(zhí)行代碼 xmlhttp = new XMLHttpRequest() } else { // IE6, IE5 瀏覽器執(zhí)行代碼 xmlhttp = new ActiveXObject("Microsoft.XMLHTTP") } xmlhttp.onreadystatechange = () => { if (xmlhttp.readyState === 4 && xmlhttp.status === 200) { document.getElementById("myDiv").innerHTML = xmlhttp.responseText } } xmlhttp.open("GET", "/ajax/test.txt", true) xmlhttp.send()使用Ajax的優(yōu)缺點(diǎn)分別是什么
優(yōu)點(diǎn)
交互性更好。來(lái)自服務(wù)器的新內(nèi)容可以動(dòng)態(tài)更改,無(wú)需重新加載整個(gè)頁(yè)面。
減少與服務(wù)器的連接,因?yàn)槟_本和樣式只需要被請(qǐng)求一次。
狀態(tài)可以維護(hù)在一個(gè)頁(yè)面上。JavaScript 變量和 DOM 狀態(tài)將得到保持,因?yàn)橹魅萜黜?yè)面未被重新加載。
基本上包括大部分 SPA 的優(yōu)點(diǎn)。
缺點(diǎn)
動(dòng)態(tài)網(wǎng)頁(yè)很難收藏。
如果 JavaScript 已在瀏覽器中被禁用,則不起作用。
有些網(wǎng)絡(luò)爬蟲(chóng)不執(zhí)行 JavaScript,也不會(huì)看到 JavaScript 加載的內(nèi)容。
基本上包括大部分 SPA 的缺點(diǎn)。
https://github.com/yangshun/f...
Ajax和Fetch區(qū)別ajax是使用XMLHttpRequest對(duì)象發(fā)起的,但是用起來(lái)很麻煩,所以ES6新規(guī)范就有了fetch,fetch發(fā)一個(gè)請(qǐng)求不用像ajax那樣寫(xiě)一大堆代碼。
使用fetch無(wú)法取消一個(gè)請(qǐng)求,這是因?yàn)閒etch基于Promise,而Promise無(wú)法做到這一點(diǎn)。
在默認(rèn)情況下,fetch不會(huì)接受或者發(fā)送cookies
fetch沒(méi)有辦法原生監(jiān)測(cè)請(qǐng)求的進(jìn)度,而XMLHttpRequest可以
fetch只對(duì)網(wǎng)絡(luò)請(qǐng)求報(bào)錯(cuò),對(duì)400,500都當(dāng)做成功的請(qǐng)求,需要封裝去處理
fetch由于是ES6規(guī)范,兼容性上比不上XMLHttpRequest
變量提升var會(huì)使變量提升,這意味著變量可以在聲明之前使用。let和const不會(huì)使變量提升,提前使用會(huì)報(bào)錯(cuò)。
變量提升(hoisting)是用于解釋代碼中變量聲明行為的術(shù)語(yǔ)。使用var關(guān)鍵字聲明或初始化的變量,會(huì)將聲明語(yǔ)句“提升”到當(dāng)前作用域的頂部。 但是,只有聲明才會(huì)觸發(fā)提升,賦值語(yǔ)句(如果有的話)將保持原樣。
用var聲明的變量的作用域是它當(dāng)前的執(zhí)行上下文,它可以是嵌套的函數(shù),也可以是聲明在任何函數(shù)外的變量。let和const是塊級(jí)作用域,意味著它們只能在最近的一組花括號(hào)(function、if-else 代碼塊或 for 循環(huán)中)中訪問(wèn)。
function foo() { // 所有變量在函數(shù)中都可訪問(wèn) var bar = "bar"; let baz = "baz"; const qux = "qux"; console.log(bar); // bar console.log(baz); // baz console.log(qux); // qux } console.log(bar); // ReferenceError: bar is not defined console.log(baz); // ReferenceError: baz is not defined console.log(qux); // ReferenceError: qux is not defined
if (true) { var bar = "bar"; let baz = "baz"; const qux = "qux"; } // 用 var 聲明的變量在函數(shù)作用域上都可訪問(wèn) console.log(bar); // bar // let 和 const 定義的變量在它們被定義的語(yǔ)句塊之外不可訪問(wèn) console.log(baz); // ReferenceError: baz is not defined console.log(qux); // ReferenceError: qux is not defined
var會(huì)使變量提升,這意味著變量可以在聲明之前使用。let和const不會(huì)使變量提升,提前使用會(huì)報(bào)錯(cuò)。
console.log(foo); // undefined var foo = "foo"; console.log(baz); // ReferenceError: can"t access lexical declaration "baz" before initialization let baz = "baz"; console.log(bar); // ReferenceError: can"t access lexical declaration "bar" before initialization const bar = "bar";
用var重復(fù)聲明不會(huì)報(bào)錯(cuò),但let和const會(huì)。
var foo = "foo"; var foo = "bar"; console.log(foo); // "bar" let baz = "baz"; let baz = "qux"; // Uncaught SyntaxError: Identifier "baz" has already been declared
let和const的區(qū)別在于:let允許多次賦值,而const只允許一次。
// 這樣不會(huì)報(bào)錯(cuò)。 let foo = "foo"; foo = "bar"; // 這樣會(huì)報(bào)錯(cuò)。 const baz = "baz"; baz = "qux";
https://github.com/yangshun/f...
對(duì)象淺拷貝和深拷貝有什么區(qū)別在 JS 中,除了基本數(shù)據(jù)類(lèi)型,還存在對(duì)象、數(shù)組這種引用類(lèi)型。
基本數(shù)據(jù)類(lèi)型,拷貝是直接拷貝變量的值,而引用類(lèi)型拷貝的其實(shí)是變量的地址。
let o1 = {a: 1} let o2 = o1
在這種情況下,如果改變 o1 或 o2 其中一個(gè)值的話,另一個(gè)也會(huì)變,因?yàn)樗鼈兌贾赶蛲粋€(gè)地址。
o2.a = 3 console.log(o1.a) // 3
而淺拷貝和深拷貝就是在這個(gè)基礎(chǔ)之上做的區(qū)分,如果在拷貝這個(gè)對(duì)象的時(shí)候,只對(duì)基本數(shù)據(jù)類(lèi)型進(jìn)行了拷貝,而對(duì)引用數(shù)據(jù)類(lèi)型只是進(jìn)行了引用的傳遞,而沒(méi)有重新創(chuàng)建一個(gè)新的對(duì)象,則認(rèn)為是淺拷貝。反之,在對(duì)引用數(shù)據(jù)類(lèi)型進(jìn)行拷貝的時(shí)候,創(chuàng)建了一個(gè)新的對(duì)象,并且復(fù)制其內(nèi)的成員變量,則認(rèn)為是深拷貝。
怎么實(shí)現(xiàn)對(duì)象深拷貝let o1 = {a:{ b:1 } } let o2 = JSON.parse(JSON.stringify(o1))
另一種方法
function deepCopy(s) { const d = {} for (let k in s) { if (typeof s[k] == "object") { d[k] = deepCopy(s[k]) } else { d[k] = s[k] } } return d }數(shù)組去重
ES5
function unique(arry) { const temp = [] arry.forEach(e => { if (temp.indexOf(e) == -1) { temp.push(e) } }) return temp }
ES6
function unique (arr) { return Array.from(new Set(arr)) }數(shù)據(jù)類(lèi)型
Undefined
Null
Boolean
Number
String
Object
symbol(ES6新增)
內(nèi)置函數(shù)(原生函數(shù))String
Number
Boolean
Object
Function
Array
Date
RegExp
Error
Symbol
原始值 "I am a string" 并不是一個(gè)對(duì)象,它只是一個(gè)字面量,并且是一個(gè)不可變的值。
如果要在這個(gè)字面量上執(zhí)行一些操作,比如獲取長(zhǎng)度、訪問(wèn)其中某個(gè)字符等,那需要將其
轉(zhuǎn)換為 String 對(duì)象。
幸好,在必要時(shí)語(yǔ)言會(huì)自動(dòng)把字符串字面量轉(zhuǎn)換成一個(gè) String 對(duì)象,也就是說(shuō)你并不需要
顯式創(chuàng)建一個(gè)對(duì)象。
Array.isArray([]) // true Array.isArray({}) // false typeof [] // "object" typeof {} // "object" Object.prototype == [].__proto__ // false Object.prototype == {}.__proto__ // true Array.prototype == [].__proto__ // true Array.prototype == {}.__proto__ // false自動(dòng)分號(hào)
有時(shí) JavaScript 會(huì)自動(dòng)為代碼行補(bǔ)上缺失的分號(hào),即自動(dòng)分號(hào)插入(Automatic SemicolonInsertion,ASI)。
因?yàn)槿绻笔Я吮匾?; ,代碼將無(wú)法運(yùn)行,語(yǔ)言的容錯(cuò)性也會(huì)降低。ASI 能讓我們忽略那些不必要的 ; 。
請(qǐng)注意,ASI 只在換行符處起作用,而不會(huì)在代碼行的中間插入分號(hào)。
如果 JavaScript 解析器發(fā)現(xiàn)代碼行可能因?yàn)槿笔Х痔?hào)而導(dǎo)致錯(cuò)誤,那么它就會(huì)自動(dòng)補(bǔ)上分
號(hào)。并且,只有在代碼行末尾與換行符之間除了空格和注釋之外沒(méi)有別的內(nèi)容時(shí),它才會(huì)
這樣做。
https://www.css88.com/archive...
cookie、localStorage、sessionStorage區(qū)別特性 | cookie | localStorage | sessionStorage |
---|---|---|---|
由誰(shuí)初始化 | 客戶端或服務(wù)器,服務(wù)器可以使用Set-Cookie請(qǐng)求頭。 | 客戶端 | 客戶端 |
數(shù)據(jù)的生命周期 | 一般由服務(wù)器生成,可設(shè)置失效時(shí)間,如果在瀏覽器生成,默認(rèn)是關(guān)閉瀏覽器之后失效 | 永久保存,可清除 | 僅在當(dāng)前會(huì)話有效,關(guān)閉頁(yè)面后清除 |
存放數(shù)據(jù)大小 | 4KB | 5MB | 5MB |
與服務(wù)器通信 | 每次都會(huì)攜帶在HTTP頭中,如果使用cookie保存過(guò)多數(shù)據(jù)會(huì)帶來(lái)性能問(wèn)題 | 僅在客戶端保存 | 僅在客戶端保存 |
用途 | 一般由服務(wù)器生成,用于標(biāo)識(shí)用戶身份 | 用于瀏覽器緩存數(shù)據(jù) | 用于瀏覽器緩存數(shù)據(jù) |
訪問(wèn)權(quán)限 | 任意窗口 | 任意窗口 | 當(dāng)前頁(yè)面窗口 |
自執(zhí)行函數(shù):1、聲明一個(gè)匿名函數(shù)2、馬上調(diào)用這個(gè)匿名函數(shù)。
作用:創(chuàng)建一個(gè)獨(dú)立的作用域。
好處:防止變量彌散到全局,以免各種js庫(kù)沖突。隔離作用域避免污染,或者截?cái)嘧饔糜蜴?,避免閉包造成引用變量無(wú)法釋放。利用立即執(zhí)行特性,返回需要的業(yè)務(wù)函數(shù)或?qū)ο螅苊饷看瓮ㄟ^(guò)條件判斷來(lái)處理
場(chǎng)景:一般用于框架、插件等場(chǎng)景
多個(gè)頁(yè)面之間如何進(jìn)行通信有如下幾個(gè)方式:
cookie
web worker
localeStorage和sessionStorage
css動(dòng)畫(huà)和js動(dòng)畫(huà)的差異代碼復(fù)雜度,js 動(dòng)畫(huà)代碼相對(duì)復(fù)雜一些
動(dòng)畫(huà)運(yùn)行時(shí),對(duì)動(dòng)畫(huà)的控制程度上,js 能夠讓動(dòng)畫(huà),暫停,取消,終止,css動(dòng)畫(huà)不能添加事件
動(dòng)畫(huà)性能看,js 動(dòng)畫(huà)多了一個(gè)js 解析的過(guò)程,性能不如 css 動(dòng)畫(huà)好
https://zhuanlan.zhihu.com/p/...
如何實(shí)現(xiàn)文件斷點(diǎn)續(xù)傳斷點(diǎn)續(xù)傳最核心的內(nèi)容就是把文件“切片”然后再一片一片的傳給服務(wù)器,但是這看似簡(jiǎn)單的上傳過(guò)程卻有著無(wú)數(shù)的坑。
首先是文件的識(shí)別,一個(gè)文件被分成了若干份之后如何告訴服務(wù)器你切了多少塊,以及最終服務(wù)器應(yīng)該如何把你上傳上去的文件進(jìn)行合并,這都是要考慮的。
因此在文件開(kāi)始上傳之前,我們和服務(wù)器要有一個(gè)“握手”的過(guò)程,告訴服務(wù)器文件信息,然后和服務(wù)器約定切片的大小,當(dāng)和服務(wù)器達(dá)成共識(shí)之后就可以開(kāi)始后續(xù)的文件傳輸了。
前臺(tái)要把每一塊的文件傳給后臺(tái),成功之后前端和后端都要標(biāo)識(shí)一下,以便后續(xù)的斷點(diǎn)。
當(dāng)文件傳輸中斷之后用戶再次選擇文件就可以通過(guò)標(biāo)識(shí)來(lái)判斷文件是否已經(jīng)上傳了一部分,如果是的話,那么我們可以接著上次的進(jìn)度繼續(xù)傳文件,以達(dá)到續(xù)傳的功能。
有了HTML5 的 File api之后切割文件比想想的要簡(jiǎn)單的多的多。
只要用slice 方法就可以了
var packet = file.slice(start, end);
參數(shù)start是開(kāi)始切片的位置,end是切片結(jié)束的位置 單位都是字節(jié)。通過(guò)控制start和end 就可以是實(shí)現(xiàn)文件的分塊
如
file.slice(0,1000); file.slice(1000,2000); file.slice(2000,3000); // ......
在把文件切成片之后,接下來(lái)要做的事情就是把這些碎片傳到服務(wù)器上。
如果中間掉線了,下次再傳的時(shí)候就得先從服務(wù)器獲取上一次上傳文件的位置,然后以這個(gè)位置開(kāi)始上傳接下來(lái)的文件內(nèi)容。
https://www.cnblogs.com/zhwl/...
new一個(gè)對(duì)象經(jīng)歷了什么function Test(){} const test = new Test()
創(chuàng)建一個(gè)新對(duì)象:
const obj = {}
設(shè)置新對(duì)象的constructor屬性為構(gòu)造函數(shù)的名稱(chēng),設(shè)置新對(duì)象的__proto__屬性指向構(gòu)造函數(shù)的prototype對(duì)象
obj.constructor = Test obj.__proto__ = Test.prototype
使用新對(duì)象調(diào)用函數(shù),函數(shù)中的this被指向新實(shí)例對(duì)象
Test.call(obj)
將初始化完畢的新對(duì)象地址,保存到等號(hào)左邊的變量中
bind、call、apply的區(qū)別call和apply其實(shí)
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/114518.html
摘要:每天會(huì)折騰一道及以上題目,并將其解題思路記錄成文章,發(fā)布到和微信公眾號(hào)上。三匯總返回目錄在月日月日這半個(gè)月中,做了匯總了數(shù)組知識(shí)點(diǎn)。或者拉到本文最下面,添加的微信等會(huì)根據(jù)題解以及留言內(nèi)容,進(jìn)行補(bǔ)充,并添加上提供題解的小伙伴的昵稱(chēng)和地址。 LeetCode 匯總 - 2019/08/15 Create by jsliang on 2019-08-12 19:39:34 Recently...
摘要:獲取的對(duì)象范圍方法獲取的是最終應(yīng)用在元素上的所有屬性對(duì)象即使沒(méi)有代碼,也會(huì)把默認(rèn)的祖宗八代都顯示出來(lái)而只能獲取元素屬性中的樣式。因此對(duì)于一個(gè)光禿禿的元素,方法返回對(duì)象中屬性值如果有就是據(jù)我測(cè)試不同環(huán)境結(jié)果可能有差異而就是。 花了很長(zhǎng)時(shí)間整理的前端面試資源,喜歡請(qǐng)大家不要吝嗇star~ 別只收藏,點(diǎn)個(gè)贊,點(diǎn)個(gè)star再走哈~ 持續(xù)更新中……,可以關(guān)注下github 項(xiàng)目地址 https:...
摘要:整理收藏一些優(yōu)秀的文章及大佬博客留著慢慢學(xué)習(xí)原文協(xié)作規(guī)范中文技術(shù)文檔協(xié)作規(guī)范阮一峰編程風(fēng)格凹凸實(shí)驗(yàn)室前端代碼規(guī)范風(fēng)格指南這一次,徹底弄懂執(zhí)行機(jī)制一次弄懂徹底解決此類(lèi)面試問(wèn)題瀏覽器與的事件循環(huán)有何區(qū)別筆試題事件循環(huán)機(jī)制異步編程理解的異步 better-learning 整理收藏一些優(yōu)秀的文章及大佬博客留著慢慢學(xué)習(xí) 原文:https://www.ahwgs.cn/youxiuwenzhan...
摘要:希望大家在這浮夸的前端圈里,保持冷靜,堅(jiān)持每天花分鐘來(lái)學(xué)習(xí)與思考。 今天的React題沒(méi)有太多的故事…… 半個(gè)月前出了248個(gè)Vue的知識(shí)點(diǎn),受到很多朋友的關(guān)注,都強(qiáng)烈要求再出多些React相前的面試題,受到大家的邀請(qǐng),我又找了20多個(gè)React的使用者,他們給出了328道React的面試題,由我整理好發(fā)給大家,同時(shí)發(fā)布在了前端面試每日3+1的React專(zhuān)題,希望對(duì)大家有所幫助,同時(shí)大...
摘要:如何考察一個(gè)人是不是經(jīng)驗(yàn)豐富我們需要在問(wèn)答式的面試中,對(duì)其項(xiàng)目經(jīng)驗(yàn)進(jìn)行挖掘。如何設(shè)置筆試題現(xiàn)在網(wǎng)上有大量的面經(jīng)的存在,對(duì)于我們面試是一個(gè)巨大的挑戰(zhàn)。尊重應(yīng)聘者我們要尊重每一個(gè)來(lái)應(yīng)聘的人,不要輕視別人,或者故意刁難別人。 時(shí)光荏苒,2個(gè)月前,我才剛總結(jié)了如何應(yīng)對(duì)面試官,現(xiàn)在的我開(kāi)始總結(jié)如何面試別人了。笑哭.png 1.我們需要什么樣的人 招聘肯定要有標(biāo)準(zhǔn),這樣我們才能更快的找到我們需要的...
閱讀 4392·2021-11-24 10:24
閱讀 1419·2021-11-22 15:22
閱讀 2047·2021-11-17 09:33
閱讀 2457·2021-09-22 15:29
閱讀 525·2019-08-30 15:55
閱讀 1666·2019-08-29 18:42
閱讀 2742·2019-08-29 12:55
閱讀 1783·2019-08-26 13:55