前端基礎(chǔ)重點回顧1: CSS盒模型、DOM晨川、數(shù)據(jù)類型

CSS盒模型

標準模型與IE模型的區(qū)別

計算高度寬度不同

標準盒模型的width 是以盒模型的content 來計算的
box-sizing: content-box

IE盒模型的width 是以盒模型的border + padding + content 來計算的
box-sizing: border-box

CSS如何設(shè)置這兩種模型

通過設(shè)置元素的box-sizing 屬性

標準盒模型設(shè)置為box-sizing: content-box
IE盒模型設(shè)置為box-sizing: border-box

JS如何設(shè)置獲取盒模型對應(yīng)的寬和高

// 獲取內(nèi)聯(lián)樣式
dom.style.width / height 
// 獲取渲染后的屬性 IE 支持
dom.currentStyle.width / height
// 獲取元素渲染后計算完畢的樣式画恰,所有瀏覽器支持
window.getComputedStyle(dom).width / height
// 計算元素的絕對位置
dom.getBoundingClientRect().width / height

dom.getBoundingClientRect() 函數(shù)不僅可以得到元素的寬高還能獲得此元素在頁面中的位置彭谁。[圖片上傳失敗...(image-a1291e-1516628501105)]

BFC

什么是BFC

BFC(block formatting context) 是一個塊級格式化上下文,它形成了一個獨立的布局環(huán)境允扇。

怎么創(chuàng)建一個BFC

1 設(shè)置float缠局,值不為”none”
2 設(shè)置overflow,值不為”visible”(hidden考润,auto狭园,scroll)
3 設(shè)置display的值為 “table-cell”, “table-caption”,或 “inline-block”
4 設(shè)置position,值不為 “static” 或 “relative”(absolute糊治,fixed)

BFC 有什么特點

1 BFC 元素內(nèi)的各元素會在垂直方向上從頂部一個接一個的放置唱矛。
2 BFC中的元素的布局是不受外界的影響,內(nèi)外元素不會互相影響。
3 BFC元素不會與浮動元素的區(qū)域重疊
4 計算BFC元素高度的時候浮動元素也會參與計算 代碼
5 屬于同一個BFC的兩個相鄰Box的margin會發(fā)生疊加 代碼

BFC 的使用場景

DOM

DOM事件的級別

// DOM0級
el.onclick=function(){}
// DOM2級
el.addEventListenter('click', function(){}, '是否捕獲階段觸發(fā)': boolean)
// DOM3級 區(qū)別DOM2級增加了更多的事件類型
el.addEventListenter('keyup', function(){}, '是否捕獲階段觸發(fā)': boolean)

DOM事件模型

  • 事件捕獲
  • 事件冒泡

DOM事件流

DOM事件流(event flow)三階段

事件觸發(fā)(觸發(fā)元素) => 事件捕獲階段(事件下傳) => 處于目標階段(達到目標元素) => 事件冒泡階段(事件上傳)

描述DOM事件捕獲的具體流程

// IE 只有冒泡流程
window => document => html(document.documentElement) => body => ... => 目標元素

如何自定義事件

Event 對象

// 創(chuàng)建
var event = new Event('custome')
// 注冊
el.addEventListener('custome', function(){
    console.log('custome')
})
el.dispatchEvent(event) // 觸發(fā)

CustomEvent 對象

var event = new CustomEvent('build', { 'detail': elem.dataset.time });
function eventHandler(e) {
  console.log('The time is: ' + e.detail);
}
el.addEventListener('custome', eventHandler)
el.dispatchEvent(event) // 觸發(fā)

Event對象的常見應(yīng)用

event.preventDefault() // 阻止默認
event.stopPropagation() // 阻止冒泡
event.stopImmediatePropagation() // 按鈕綁定兩個click井辜,A點擊時候不出發(fā)B绎谦,A會成功阻止B, 事件響應(yīng)優(yōu)先級
event.target // 可以用于事件委托,由父級注冊事件
event.currentTarget

currentTarget vs target

target在事件流的目標階段粥脚;currentTarget在事件流的捕獲窃肠,目標及冒泡階段。只有當事件流處在目標階段的時候刷允,兩個的指向才是一樣的冤留, 而當處于捕獲和冒泡階段的時候,target指向被單擊的對象而currentTarget指向當前事件活動的對象(一般為父級)树灶。

類型轉(zhuǎn)換

  • 數(shù)據(jù)類型

    • 原始類型

    Boolean, String, Number, Null, Undefined, Symbol

    • 復雜類型(對象)

    Object

  • 顯式類型轉(zhuǎn)換
    Number函數(shù)

    簡單類型: 直接轉(zhuǎn)換end
    復雜類型: valueOf() => 簡單類型 => 直接轉(zhuǎn)換end || 復雜類型 => toString() => 簡單類型 =>
    直接轉(zhuǎn)換end

    String函數(shù)

    簡單類型: 直接轉(zhuǎn)換end
    復雜類型: toString() => 簡單類型 => 直接轉(zhuǎn)換end || 復雜類型 => valueOf() => 簡單類型 =>
    直接轉(zhuǎn)換end || 復雜類型error

    Boolean函數(shù)

    空字符串纤怒、Null、undefined破托、false肪跋、0 轉(zhuǎn)化為false

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市土砂,隨后出現(xiàn)的幾起案子州既,更是在濱河造成了極大的恐慌谜洽,老刑警劉巖,帶你破解...
    沈念sama閱讀 212,542評論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件吴叶,死亡現(xiàn)場離奇詭異阐虚,居然都是意外死亡,警方通過查閱死者的電腦和手機蚌卤,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,596評論 3 385
  • 文/潘曉璐 我一進店門实束,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人逊彭,你說我怎么就攤上這事咸灿。” “怎么了侮叮?”我有些...
    開封第一講書人閱讀 158,021評論 0 348
  • 文/不壞的土叔 我叫張陵避矢,是天一觀的道長。 經(jīng)常有香客問我囊榜,道長审胸,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,682評論 1 284
  • 正文 為了忘掉前任卸勺,我火速辦了婚禮砂沛,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘曙求。我一直安慰自己碍庵,他們只是感情好,可當我...
    茶點故事閱讀 65,792評論 6 386
  • 文/花漫 我一把揭開白布圆到。 她就那樣靜靜地躺著怎抛,像睡著了一般。 火紅的嫁衣襯著肌膚如雪芽淡。 梳的紋絲不亂的頭發(fā)上马绝,一...
    開封第一講書人閱讀 49,985評論 1 291
  • 那天,我揣著相機與錄音挣菲,去河邊找鬼富稻。 笑死,一個胖子當著我的面吹牛白胀,可吹牛的內(nèi)容都是我干的椭赋。 我是一名探鬼主播,決...
    沈念sama閱讀 39,107評論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼或杠,長吁一口氣:“原來是場噩夢啊……” “哼哪怔!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,845評論 0 268
  • 序言:老撾萬榮一對情侶失蹤认境,失蹤者是張志新(化名)和其女友劉穎胚委,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體叉信,經(jīng)...
    沈念sama閱讀 44,299評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡亩冬,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,612評論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了硼身。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片硅急。...
    茶點故事閱讀 38,747評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖佳遂,靈堂內(nèi)的尸體忽然破棺而出营袜,到底是詐尸還是另有隱情,我是刑警寧澤讶迁,帶...
    沈念sama閱讀 34,441評論 4 333
  • 正文 年R本政府宣布连茧,位于F島的核電站,受9級特大地震影響巍糯,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜客扎,卻給世界環(huán)境...
    茶點故事閱讀 40,072評論 3 317
  • 文/蒙蒙 一祟峦、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧徙鱼,春花似錦宅楞、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,828評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至绞绒,卻和暖如春婶希,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背蓬衡。 一陣腳步聲響...
    開封第一講書人閱讀 32,069評論 1 267
  • 我被黑心中介騙來泰國打工喻杈, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人狰晚。 一個月前我還...
    沈念sama閱讀 46,545評論 2 362
  • 正文 我出身青樓筒饰,卻偏偏與公主長得像,于是被迫代替她去往敵國和親壁晒。 傳聞我的和親對象是個殘疾皇子瓷们,可洞房花燭夜當晚...
    茶點故事閱讀 43,658評論 2 350

推薦閱讀更多精彩內(nèi)容

  • 問答題47 /72 常見瀏覽器兼容性問題與解決方案? 參考答案 (1)瀏覽器兼容問題一:不同瀏覽器的標簽默認的外補...
    _Yfling閱讀 13,737評論 1 92
  • 1.行內(nèi)元素和塊級元素?img算什么?行內(nèi)元素怎么轉(zhuǎn)化為塊級元素? 行內(nèi)元素:和有他元素都在一行上,高度谬晕、行高及外...
    極樂君閱讀 2,411評論 0 20
  • 一:在制作一個Web應(yīng)用或Web站點的過程中式镐,你是如何考慮他的UI、安全性固蚤、高性能娘汞、SEO、可維護性以及技術(shù)因素的...
    Arno_z閱讀 1,141評論 0 1
  • “媽媽,我們錯了燎孟,媽媽你就饒了我們吧禽作,”隔壁又傳來了女孩的哭喊聲】常“唉旷偿!”我嘆氣,這已經(jīng)不知是第幾次了爆侣! 剛搬來的...
    清澤閱讀 411評論 2 2
  • 心門已經(jīng)關(guān)閉就難以敞開萍程。是因為鎖太緊,那鎖肯定沒有找到合適的鑰匙兔仰。是因為門太死茫负,那也許就不必再費勁敞開,...
    云上行者168閱讀 179評論 0 0