摘要:開發(fā)中的實(shí)踐盡量使用更換實(shí)現(xiàn)樣式變化。原因事件存在毫秒延時(shí)。解決方法移動端使用事件。文本顯示省略號顯示省略號的基本條件元素定長。單行顯示省略號多行顯示省略號目前只有內(nèi)核支持此屬性和手機(jī)端內(nèi)核以及瀏覽器默認(rèn)字體瀏覽器默認(rèn)字體是。
1、輸入U(xiǎn)RL到顯示網(wǎng)頁,中間發(fā)生了什么
DNS(完成域名到IP的映射)-->TCP傳輸(三次握手建立傳輸鏈接)-->發(fā)送請求(分析url,設(shè)置請求頭、主體)-->服務(wù)器返回請求文件(HTML文件)-->瀏覽器渲染頁面(DOM tree渲染,css tree渲染,Rander tree渲染,layout布局,GPU完成像素渲染頁面)
2、網(wǎng)絡(luò)協(xié)議(七層)
物理層(以比特流為單位傳輸)-->數(shù)據(jù)鏈路層(封裝楨,把數(shù)據(jù)從一個(gè)MAC傳到另一個(gè)MAC)-->網(wǎng)絡(luò)層(路徑的選擇,網(wǎng)絡(luò)的轉(zhuǎn)發(fā))-->傳輸層(建立鏈接,傳送報(bào)文,TCP、UDP)-->會話層(發(fā)起會話)-->表示層(數(shù)據(jù)表示方式的轉(zhuǎn)化)-->應(yīng)用層(面向用戶,DNS、FTP、E-mail、HTTP)
3、頁面的重繪和回流
重繪(repaint):頁面元素樣式發(fā)生變化,但不引起結(jié)構(gòu)布局改變時(shí),瀏覽器只在UI層面進(jìn)行重繪和更新,稱為重繪。
回流(reflow):頁面的結(jié)構(gòu)、布局或者操作觸發(fā)某些屬性,引起的瀏覽器重新就算、布局,稱為回流。
引起回流的操作:①頁面的初次渲染 ②頁面尺寸的改變 ③元素的尺寸、位置發(fā)生改變 ④字體的大小改變 ⑤刪除、添加元素 ⑥激活偽類 ⑦觸發(fā)某些屬性(offsetWidth系列、clientWidth系列、scrollTop系列、getComputedStyle()、getBoundingClientRect()、scrollTo())
回流一定引起重繪,重繪不一定引起回流,重繪開銷較小。
開發(fā)中的實(shí)踐:①盡量使用更換class實(shí)現(xiàn)樣式變化。②盡量減少DOM操作,把多次DOM操作,集中一次修改。
4、點(diǎn)透問題
描述:發(fā)生在z層的上下兩層DOM元素,點(diǎn)擊上層A元素時(shí),A元素隱藏,下層B元素也觸發(fā)點(diǎn)擊事件的現(xiàn)象。
原因:click事件存在300毫秒延時(shí)。
解決方法:移動端使用touch事件。
click事件發(fā)生的過程:mousedown->mouseup->click
觸摸屏幕上元素時(shí):touchstart->mouseover->mousemove->mousedown->mouseup->click->touchend
5、滑動穿透問題(移動端)
https://uedsky.com/2016-06/mo...
描述:在移動端,當(dāng)彈出一個(gè)fixed浮層,滾動浮層,下層也會跟隨滾動。
原因:尚未知
解決方法:
①禁止html,body元素滾動,浮層消失用js恢復(fù)滾動---overflow:hidden(整個(gè)文檔失去滾動,彈出框也失去滾動)
②記錄當(dāng)前的滾動位置,讓整個(gè)文檔脫離文檔流,把文檔拉回記錄的位置;浮層消失時(shí)恢復(fù)之前的設(shè)置。
body.modal-open {
position: fixed; width: 100%;
}
如果只是上面的 css,滾動條的位置同樣會丟失
所以如果需要保持滾動條的位置需要用 js 保存滾動條位置關(guān)閉的時(shí)候還原滾動位置
JavaScript
/**
ModalHelper helpers resolve the modal scrolling issue on mobile devices
https://github.com/twbs/boots...
requires document.scrollingElement polyfill https://github.com/yangg/scro...
*/
var ModalHelper = (function(bodyCls) { var scrollTop; return { afterOpen: function() { scrollTop = document.scrollingElement.scrollTop; document.body.classList.add(bodyCls); document.body.style.top = -scrollTop + "px"; }, beforeClose: function() { document.body.classList.remove(bodyCls); // scrollTop lost after set position:fixed, restore it back. document.scrollingElement.scrollTop = scrollTop; } }; })("modal-open");
說明:document.scrollingElement.scrollTop是獲取和設(shè)置文檔滾動高度的通用方法。
document.documentElement.scrollTop可獲取PC端的滾動高度(移動端恒為0)
document.body.scrollTop可獲取移動端的滾動高度(PC端恒為0)
6、類型轉(zhuǎn)換
==:發(fā)生強(qiáng)制類型轉(zhuǎn)換,其中undefined==null,NAN!=NAN,布爾值和0/1互轉(zhuǎn),字符串轉(zhuǎn)布爾值(是否為空),字符串轉(zhuǎn)數(shù)字(數(shù)字直接轉(zhuǎn),非數(shù)字轉(zhuǎn)為NAN),對象是否相等取決于是否引用同一對象(對象轉(zhuǎn)布爾值--是否為null)。
Number()/Boolean()/toString()/
+:一個(gè)為字符串,另一個(gè)調(diào)用toString()方法轉(zhuǎn)成字符串;兩個(gè)數(shù)字直接相加;兩個(gè)字符串直接拼接。
7、判斷兩個(gè)值相等
==:相等,具有強(qiáng)制轉(zhuǎn)化的特點(diǎn)。
===:全等運(yùn)算符,不強(qiáng)制轉(zhuǎn)換,但對+0/-0判斷為true,NaN===NaN的判斷為false
Object.is(par1,par2):可準(zhǔn)確判斷,-0和+0是兩個(gè)不同的值(ES6新添方法)
8、DOM中的高度
每個(gè)DOM元素都會有五種高度屬性:offsetHeight、clientHeight、scrollHeight、offsetTop、scrollTop。
offsetHeight:height+padding+border+水平滾動條的高度。
clientHeight:height+padding。
scrollHeight:無滾動條時(shí)=clientHeight,有滾動條時(shí)=包含滾去高度的整體高度
offsetTop:當(dāng)前元素距離最近父元素的高度,和滾動條出現(xiàn)與否無關(guān)。
scrollTop:發(fā)生滾動時(shí),頁面滾去的高度。
9、文本顯示省略號
顯示省略號的基本條件:元素定長。
單行顯示省略號:overflow:hidden; text-overflow: ellipsis; white-space: nowrap;
多行顯示省略號:(目前只有webkit內(nèi)核支持此屬性---Chrome、Safari和手機(jī)端內(nèi)核)
overflow: hidden;
text-overflow: ellipsis;
display: -webkit-box;
-webkit-clamp: 2;
-webkit-box-orient: vertical;
10、px、em、rem以及瀏覽器默認(rèn)字體
瀏覽器默認(rèn)字體是16px。chrom顯示的最小字體是12px,F(xiàn)irefox支持顯示更小的字體。
px是物理像素,不可自適應(yīng)大小。
em是相對大小,繼承自父元素。
rem是相對大小,繼承自html根元素。(IE8及更早版本不支持)
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/53676.html
摘要:與面向?qū)ο缶幊塘蠓较蛑阃黄魄岸松钠脚_期前端掘金無論我們從事何種職業(yè),在職業(yè)生涯的某個(gè)階段,都或多或少會遇到所謂的平臺期。目前為止,已經(jīng)有個(gè)用戶通過認(rèn)證登觀點(diǎn)年前端初學(xué)者的生存指南前端掘金逝者如斯夫,不舍晝夜。 你可能聽說過函數(shù)式編程(Functional programming),甚至已經(jīng)使用了一段時(shí)間。 但是,你能說清楚,它到底是什么嗎? 網(wǎng)上搜索一下,你會輕松找到好多答案...
摘要:前言一直混跡社區(qū)突然發(fā)現(xiàn)自己收藏了不少好文但是管理起來有點(diǎn)混亂所以將前端主流技術(shù)做了一個(gè)書簽整理不求最多最全但求最實(shí)用。 前言 一直混跡社區(qū),突然發(fā)現(xiàn)自己收藏了不少好文但是管理起來有點(diǎn)混亂; 所以將前端主流技術(shù)做了一個(gè)書簽整理,不求最多最全,但求最實(shí)用。 書簽源碼 書簽導(dǎo)入瀏覽器效果截圖showImg(https://segmentfault.com/img/bVbg41b?w=107...
摘要:開發(fā)中的實(shí)踐盡量使用更換實(shí)現(xiàn)樣式變化。原因事件存在毫秒延時(shí)。解決方法移動端使用事件。文本顯示省略號顯示省略號的基本條件元素定長。單行顯示省略號多行顯示省略號目前只有內(nèi)核支持此屬性和手機(jī)端內(nèi)核以及瀏覽器默認(rèn)字體瀏覽器默認(rèn)字體是。 1、輸入U(xiǎn)RL到顯示網(wǎng)頁,中間發(fā)生了什么 DNS(完成域名到IP的映射)-->TCP傳輸(三次握手建立傳輸鏈接)-->發(fā)送請求(分析url,設(shè)置請求頭、主體)-...
摘要:開發(fā)中的實(shí)踐盡量使用更換實(shí)現(xiàn)樣式變化。原因事件存在毫秒延時(shí)。解決方法移動端使用事件。文本顯示省略號顯示省略號的基本條件元素定長。單行顯示省略號多行顯示省略號目前只有內(nèi)核支持此屬性和手機(jī)端內(nèi)核以及瀏覽器默認(rèn)字體瀏覽器默認(rèn)字體是。 1、輸入U(xiǎn)RL到顯示網(wǎng)頁,中間發(fā)生了什么 DNS(完成域名到IP的映射)-->TCP傳輸(三次握手建立傳輸鏈接)-->發(fā)送請求(分析url,設(shè)置請求頭、主體)-...
摘要:我對知乎前端相關(guān)問題的十問十答張鑫旭張鑫旭大神對知乎上經(jīng)典的個(gè)前端問題的回答。作者對如何避免常見的錯(cuò)誤,難以發(fā)現(xiàn)的問題,以及性能問題和不好的實(shí)踐給出了相應(yīng)的建議。但并不是本身有問題,被標(biāo)準(zhǔn)定義的是極好的。 這一次,徹底弄懂 JavaScript 執(zhí)行機(jī)制 本文的目的就是要保證你徹底弄懂javascript的執(zhí)行機(jī)制,如果讀完本文還不懂,可以揍我。 不論你是javascript新手還是老...
閱讀 2274·2021-11-25 09:43
閱讀 3147·2021-10-14 09:42
閱讀 3497·2021-10-12 10:12
閱讀 1580·2021-09-07 10:17
閱讀 1912·2019-08-30 15:54
閱讀 3197·2019-08-30 15:54
閱讀 1570·2019-08-30 15:53
閱讀 1930·2019-08-29 11:21