日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 前端技术 > HTML >内容正文

HTML

promise的状态以及api介绍_2019年,盘点一些我出过的前端面试题以及对求职者的建议

發(fā)布時(shí)間:2025/3/12 HTML 51 豆豆
生活随笔 收集整理的這篇文章主要介紹了 promise的状态以及api介绍_2019年,盘点一些我出过的前端面试题以及对求职者的建议 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

筆者雖然曾經(jīng)也面試過很多求職者,但是對于前端的筆試和面試,我覺得并不能體現(xiàn)一個(gè)人的真實(shí)能力,所以建議大家多修煉前端真正的技術(shù).對于前端面試題,之前也承諾過讀者要出一篇,筆者大致總結(jié)一下曾經(jīng)面試的題目.后續(xù)不會(huì)再出面試題,而是聚焦于一些真正的,有利于成長性的技術(shù)文章和思維方式,來幫助大家提高解決問題的能力.

前言

首先總結(jié)一下筆者對于前端領(lǐng)于學(xué)習(xí)的一些成長模型和學(xué)習(xí)路線,來給大家提供一些參考.

下面推薦一些不同技術(shù)選型的優(yōu)秀組件和庫,也是筆者曾今使用過的.

如果公司的前端是以vue為主的,那么你可能需要熟悉如下技能和知識(shí)點(diǎn)

  • vue
  • vue-router 路由管理
  • vuex 狀態(tài)管理
  • vue-cli3 vue項(xiàng)目優(yōu)秀的腳手架,可以配置單頁,多頁,ssr, 預(yù)渲染技術(shù)的頁面
  • vue-server-renderer 服務(wù)端渲染方案
  • vue-devtools vue開發(fā)調(diào)試工具,方便調(diào)試大型復(fù)雜項(xiàng)目
  • antd-desigin-vue / element UI 基于vue的第三方ui組件庫
  • vxe-table 優(yōu)秀的vue表格解決方案
  • vue-multiselect vue強(qiáng)大的多選下拉組件
  • Vuelidate 基于vue強(qiáng)大且輕量的校驗(yàn)庫
  • vuex-router-sync 保持vue-router和vuex store同步

如果公司的前端是以React為主的,那么你可能需要熟悉如下技能和知識(shí)點(diǎn)

  • react
  • react-router
  • react-thunk 異步redux解決方案
  • ant design 優(yōu)秀且強(qiáng)大的react組件庫
  • react-json-view JSON 顯示器
  • react-quill 富文本編輯器
  • rc-color-picker 拾色器
  • qrcode.react 二維碼生成器
  • antV 數(shù)據(jù)可視化解決方案
  • react-beautiful-dnd 基于react的拖拽庫
  • emoji-mart 表情庫
  • react-image-crop 圖片裁切
  • Ant Motion 動(dòng)畫
  • react-codemirror2 代碼編輯器
  • react-copy-to-clipboard 復(fù)制到剪切板

接下來言歸正傳,開始進(jìn)入正文.

正文

1. 介紹一下ES6的新特性

[參考答案]

  • const和let
  • 模板字符串
  • 箭頭函數(shù)
  • 函數(shù)的參數(shù)默認(rèn)值
  • Spread / Rest 操作符
  • 二進(jìn)制和八進(jìn)制字面量(通過在數(shù)字前面添加0o或0O即可將其轉(zhuǎn)為八進(jìn)制值,二進(jìn)制使用0b或者0B)
  • 對象和數(shù)組結(jié)構(gòu)
  • ES6中的類(class)
  • Promise
  • Set()和Map()數(shù)據(jù)結(jié)構(gòu)
  • Modules(模塊, 如import, export)
  • for..of 循環(huán)

2. 介紹Promise以及Promise的幾種狀態(tài)

[參考答案]

介紹: Promise 是異步編程的一種解決方案,比傳統(tǒng)的解決方案——回調(diào)函數(shù)和事件——更合理和更強(qiáng)大。所謂Promise,簡單說就是一個(gè)容器,里面保存著某個(gè)未來才會(huì)結(jié)束的事件(通常是一個(gè)異步操作)的結(jié)果。從語法上說,Promise 是一個(gè)對象,從它可以獲取異步操作的消息。Promise 提供統(tǒng)一的 API,各種異步操作都可以用同樣的方法進(jìn)行處理。 狀態(tài): pending(進(jìn)行中)、fulfilled(已成功)和rejected(已失敗)。只有異步操作的結(jié)果,可以決定當(dāng)前是哪一種狀態(tài),任何其他操作都無法改變這個(gè)狀態(tài)。

3. 談?wù)勀銓﹂]包的理解及其優(yōu)缺點(diǎn)

[參考答案]

閉包就是能夠讀取其他函數(shù)內(nèi)部變量的函數(shù). 本質(zhì)上,閉包是將函數(shù)內(nèi)部和函數(shù)外部連接起來的橋梁.

優(yōu)點(diǎn)

  • 邏輯連續(xù),當(dāng)閉包作為另一個(gè)函數(shù)調(diào)用參數(shù)時(shí),避免脫離當(dāng)前邏輯而單獨(dú)編寫額外邏輯。
  • 延長局部變量的生命周期, 更具有封裝性, 保護(hù)局部變量。

缺點(diǎn)

  • 容易造成內(nèi)存溢出
  • 閉包會(huì)在父函數(shù)外部,改變父函數(shù)內(nèi)部變量的值,所以可能會(huì)導(dǎo)致改變父函數(shù)的變量

4. React的生命周期

[參考答案]

  • 初始化階段 defaultProps -> constructor -> componentWillMount() -> render() -> componentDidMount()
  • 運(yùn)行中階段 componentWillReceiveProps() -> shouldComponentUpdate() -> componentWillUpdate() -> componentDidUpdate()
  • 銷毀階段 componentWillUnmount()

5. componentWillReceiveProps的觸發(fā)條件是什么

[參考答案] componentWillReceiveProps會(huì)在接收到新的props的時(shí)候調(diào)用

6. vue中v-if和v-show的區(qū)別

[參考答案]

  • v-show不管條件是真還是佳,第一次渲染的時(shí)候標(biāo)簽都會(huì)添加到DOM中。切換的時(shí)候,通過display: none;樣式來顯示隱藏元素,對性能影響不是很大。
  • v-if在首次渲染的時(shí)候,如果條件為假,不會(huì)在頁面渲染該元素。當(dāng)條件為真時(shí),開始局部編譯,動(dòng)態(tài)的向DOM元素里面添加元素。當(dāng)條件從真變?yōu)榧俚臅r(shí)候,開始局部編譯,卸載這些元素,也就是刪除。對性能有一定影響

7. 小程序里面開頁面最多多少

[參考答案] 小程序原生頁面存在層級限制,超過一定層數(shù)就會(huì)無法打開新頁面。一開始這個(gè)限制為不超過5層,目前是不超過10層。

8. 取數(shù)組的最大值(ES5、ES6)

[參考答案]

// es5Math.max.apply(null, arr);// es6Math.max(...arr);復(fù)制代碼

9. http并發(fā)請求資源數(shù)上限

[參考答案] HTTP客戶端一般對同一個(gè)服務(wù)器的并發(fā)連接個(gè)數(shù)都是有限制的, 最大為6條

10. 如何優(yōu)化網(wǎng)站的SEO

[參考答案]

  • 網(wǎng)站結(jié)構(gòu)布局優(yōu)化:盡量簡單, 提倡扁平化結(jié)構(gòu). 一般而言,建立的網(wǎng)站結(jié)構(gòu)層次越少,越容易被“蜘蛛”抓取,也就容易被收錄。
  • img標(biāo)簽必須添加“alt”和“title”屬性,告訴搜索引擎導(dǎo)航的定位,做到即使圖片未能正常顯示時(shí),用戶也能看到提示文字。
  • 把重要內(nèi)容HTML代碼放在最前搜索引擎抓取HTML內(nèi)容是從上到下,利用這一特點(diǎn),可以讓主要代碼優(yōu)先讀取,廣告等不重要代碼放在下邊。
  • 控制頁面的大小,減少http請求,提高網(wǎng)站的加載速度。
  • 合理的設(shè)計(jì)title、description和keywords
    • title標(biāo)題:只強(qiáng)調(diào)重點(diǎn)即可,盡量把重要的關(guān)鍵詞放在前面,關(guān)鍵詞不要重復(fù)出現(xiàn),盡量做到每個(gè)頁面的title標(biāo)題中不要設(shè)置相同的內(nèi)容。
    • meta keywords頁面/網(wǎng)站的關(guān)鍵字。
    • meta description網(wǎng)頁描述,需要高度概括網(wǎng)頁內(nèi)容,切記不能太長,過分堆砌關(guān)鍵詞,每個(gè)頁面也要有所不同。
  • 語義化書寫HTML代碼,符合W3C標(biāo)準(zhǔn)盡量讓代碼語義化,在適當(dāng)?shù)奈恢檬褂眠m當(dāng)?shù)臉?biāo)簽,用正確的標(biāo)簽做正確的事。讓閱讀源碼者和“蜘蛛”都一目了然。
  • a標(biāo)簽:頁面鏈接,要加 “title” 屬性說明,鏈接到其他網(wǎng)站則需要加上 el="nofollow" 屬性, 告訴 “蜘蛛” 不要怕,因?yàn)橐坏爸┲搿迸懒送獠挎溄又?#xff0c;就不會(huì)再回來了。
  • 圖標(biāo)使用IconFont替換
  • 使用CDN網(wǎng)絡(luò)緩存,加快用戶訪問速度,減輕服務(wù)器壓力
  • 啟用GZIP壓縮,瀏覽速度變快,搜索引擎的蜘蛛抓取信息量也會(huì)增大
  • SSR技術(shù)
  • 預(yù)渲染技術(shù)
  • 11. 介紹下HTTP狀態(tài)碼, 403、301、302分別代表什么

    [參考答案]

    當(dāng)瀏覽者訪問一個(gè)網(wǎng)頁時(shí),瀏覽者的瀏覽器會(huì)向網(wǎng)頁所在服務(wù)器發(fā)出請求。當(dāng)瀏覽器接收并顯示網(wǎng)頁前,此網(wǎng)頁所在的服務(wù)器會(huì)返回一個(gè)包含HTTP狀態(tài)碼的信息頭(server header)用以響應(yīng)瀏覽器的請求。

    • 301 (永久移動(dòng)) 請求的網(wǎng)頁已永久移動(dòng)到新位置。 服務(wù)器返回此響應(yīng)(對 GET 或 HEAD 請求的響應(yīng))時(shí),會(huì)自動(dòng)將請求者轉(zhuǎn)到新位置
    • 302 (臨時(shí)移動(dòng)) 服務(wù)器目前從不同位置的網(wǎng)頁響應(yīng)請求,但請求者應(yīng)繼續(xù)使用原有位置來進(jìn)行以后的請求
    • 403 (禁止) 服務(wù)器拒絕請求

    12. RESTful常用的方法和介紹

    [參考答案] rest請求方法有4種,包括get,post,put,delete.分別對應(yīng)獲取資源,添加資源,更新資源及刪除資源.

    12. React16.3對生命周期的改變

    [參考答案] React16.3+廢棄的三個(gè)生命周期函數(shù)

    • componentWillMount
    • componentWillReceiveProps
    • componentWillUpdate

    取而代之的是兩個(gè)新的生命周期函數(shù)

    • static getDerivedStateFromProps(nextProps, prevState) 取代componentWillMount、componentWillReceiveProps和componentWillUpdate
    • getSnapshotBeforeUpdate(prevProps, prevState) 取代componentWillUpdate
    class ScrollingList extends React.Component { constructor(props) { super(props); this.listRef = React.createRef(); } getSnapshotBeforeUpdate(prevProps, prevState) { // 返回的數(shù)據(jù)將作為componentDidUpdate第三個(gè)參數(shù) return { stateA: 'xxx' }; } componentDidUpdate(prevProps, prevState, snapshot) { if (snapshot !== null) { console.log(snapshot.stateA) } } render() {}}復(fù)制代碼

    13. 介紹React高階組件

    高階組件(HOC)是 React 中用于復(fù)用組件邏輯的一種高級技巧。HOC 自身不是 React API 的一部分,它是一種基于 React 的組合特性而形成的設(shè)計(jì)模式。具體而言,高階組件是參數(shù)為組件,返回值為新組件的函數(shù).其本身是純函數(shù),沒有副作用。

    function logProps(WrappedComponent) { return class extends React.Component { componentWillReceiveProps(nextProps) { console.log('Current props: ', this.props); console.log('Next props: ', nextProps); } render() { // 將 input 組件包裝在容器中,而不對其進(jìn)行修改。Good! return ; } }}復(fù)制代碼

    14. 緩存相關(guān)的HTTP請求頭

    [參考答案]

    headers字段 解釋 案例 Expires 服務(wù)端告訴瀏覽器,先把這個(gè)文件緩存起來,在這個(gè)過期時(shí)間之前,該文件都不會(huì)變化 Expires: Mon, 1 Aug 2016 22:43:02 GMT Cache-Control 由于Expires給定的是絕對時(shí)間,而客戶端的系統(tǒng)時(shí)間可以由用戶任意修改, Cache-Control為相對時(shí)間 Cache-Control: max-age=80 Last-Modified(response header) / If-Modified-Since (request header) 服務(wù)端收到請求后會(huì)對比目前文件的最后修改時(shí)間和該請求頭的信息,如果沒有修改,那就直接返回304給瀏覽器,而不返回實(shí)際資源。如果有變化了,就返回200,并且?guī)闲碌馁Y源內(nèi)容 If-Modified-Since:Mon, 01 Aug 2016 13:48:44 GMT Etag / If-None-Match 第一次請求后響應(yīng)頭中包含了Etag,作為時(shí)間標(biāo)簽,下一次請求時(shí)會(huì)把原來的Etag標(biāo)簽帶上(在請求頭中變成了If-None-Match)作為校驗(yàn)標(biāo)準(zhǔn),若這個(gè)文件如果發(fā)生了改變,則Etag也會(huì)改變。服務(wù)器對比瀏覽器請求頭中的的If-None-Match:如果相同就返回304,而不返回實(shí)際資源如果不同,就返回200和新的資源。

    15. 如何優(yōu)化用戶體驗(yàn)

    [參考答案]

    • 頁面渲染前使用骨架屏或者加載動(dòng)畫,避免大塊白屏
    • 使用預(yù)渲染或者ssr技術(shù)提高首屏加載時(shí)間
    • 動(dòng)畫使用css3硬件加速,避免用戶操作動(dòng)畫卡頓
    • 計(jì)算密集型業(yè)務(wù)使用web worker或者js分片處理,避免js線程阻塞
    • 頁面狀態(tài)監(jiān)控,給用戶提供反饋機(jī)制
    • 靜態(tài)資源走CDN緩存或者oss服務(wù),提高用戶訪問速度
    • 避免用戶操作報(bào)錯(cuò),提供404頁面或者錯(cuò)誤提示頁面

    16. 對PWA的了解

    [參考答案]

    progressive web app: 漸進(jìn)式網(wǎng)頁應(yīng)用.可以將 Web 和 App 各自的優(yōu)勢融合在一起:漸進(jìn)式、可響應(yīng)、可離線、實(shí)現(xiàn)類似 App 可交互、即時(shí)更新、安全、可以被搜索引擎檢索、可推送、可安裝、可鏈接。其核心技術(shù)包括 App Manifest、Service Worker、Web Push,等等。

    17. 介紹下跨域

    [參考答案]

    同源策略/SOP(Same origin policy)是一種約定,它是瀏覽器最核心也最基本的安全功能,如果缺少了同源策略,瀏覽器很容易受到XSS、CSFR等攻擊, 同源策略要求兩個(gè)通訊地址的協(xié)議、域名、端口號必須相同,否則兩個(gè)地址的通訊將被瀏覽器視為不安全的,并被阻擋下來. 要突破SOP的限制,我們可以使用如下方式:

    • CORS 同域安全策略CORS是一種跨域資源請求機(jī)制,它要求當(dāng)前域在響應(yīng)報(bào)頭添加Access-Control-Allow-Origin標(biāo)簽,從而允許指定域的站點(diǎn)訪問當(dāng)前域上的資源
    res.setHeader("Access-Control-Allow-Origin","*"); // 不過CORS默認(rèn)只支持GET/POST這兩種http請求類型,如果要開啟PUT/DELETE之類的方式,需要在服務(wù)端在添加一個(gè)"Access-Control-Allow-Methods"報(bào)頭標(biāo)簽: res.setHeader( "Access-Control-Allow-Methods", "PUT, GET, POST, DELETE, HEAD, PATCH" )復(fù)制代碼
    • HTML5 postMessage 可以使用 postMessage 方法和 onmessage 事件來實(shí)現(xiàn)不同域之間的通信,其中postMessage用于實(shí)時(shí)向接收信息的頁面發(fā)送消息
    • HTML5 WebSocket WebSocket protocol 是HTML5一種新的協(xié)議。它實(shí)現(xiàn)了瀏覽器與服務(wù)器全雙工通信,同時(shí)允許跨域通訊,是server push技術(shù)的一種很棒的實(shí)現(xiàn)
    • JSONP 是JSON的一種“使用模式”,主要是利用script標(biāo)簽不受同源策略限制的特性,向跨域的服務(wù)器請求并返回一段JSON數(shù)據(jù)
    • iframe形式 通過設(shè)置相同的document.domain, 或者不同域通過window.name傳遞數(shù)據(jù)
    • 服務(wù)器代理

    18. Access-Control-Allow-Origin在服務(wù)端哪里配置

    [參考答案] response header響應(yīng)頭

    19. csrf跨站攻擊怎么解決

    [參考答案]

    CSRF, 跨站請求偽造,它可以在用戶毫不知情的情況下以用戶名義偽造請求發(fā)送給受攻擊站點(diǎn),從而對用戶或者網(wǎng)站造成攻擊. 預(yù)防措施如下:

    • 服務(wù)器端驗(yàn)證HTTP Referer字段, Referer記錄了該HTTP請求的來源地址
    • 在請求地址中添加token并驗(yàn)證
    • 在HTTP頭中自定義屬性并驗(yàn)證

    20. 用js寫一個(gè)數(shù)組扁平化函數(shù)

    [參考答案]

    // reducefunction flatten(arr = []) { return arr.reduce((result, item) => { return result.concat(Array.isArray(item) ? flatten(item) : item) }, [])}// (toString | join) & split(利用數(shù)組的toString或者join,將數(shù)組轉(zhuǎn)化為字符串)function flatten(arr = []) { return arr.toString().split(',').map(item => Number(item))}復(fù)制代碼

    21. Promise和Callback有什么區(qū)別

    [參考答案]

    相比于callback,Promise 具有更易讀的代碼組織形式(鏈?zhǔn)浇Y(jié)構(gòu)調(diào)用),更好的異常處理方式(在調(diào)用 Promise 的末尾添加上一個(gè)catch方法捕獲異常即可),以及異步操作并行處理的能力(Promise.all()Promise.race()等)。callback最大的問題就是我們通常說的回調(diào)地獄,一旦業(yè)務(wù)邏輯復(fù)雜了,我們不得不使用大量的嵌套回調(diào)代碼,可維護(hù)性很低.

    22. 如何實(shí)現(xiàn)高度自適應(yīng)

    [參考答案]

    • 使用絕對定位, 設(shè)置top,bottom屬性
    • 使用flex布局
    • float+ height:100%

    23. cookie, session, storage的區(qū)別和聯(lián)系

    [參考答案]

    • cookie存儲(chǔ)于瀏覽器端,而session存儲(chǔ)于服務(wù)端
    • cookie的安全性相比于session較弱,cookie容易被第三方劫持,考慮到安全應(yīng)當(dāng)使用session
    • session保存在服務(wù)器上,當(dāng)訪問增多時(shí),會(huì)占用服務(wù)器的資源
    • cookie存儲(chǔ)容量有限制,單個(gè)cookie保存數(shù)據(jù)不能超過4k,且很多瀏覽器限制一個(gè)站點(diǎn)最多保存20個(gè)cookie。對于session,默認(rèn)大小一般是1M
    • cookie、sessionStorage、localStorage,都保存在瀏覽器端,且受同源策略影響
    • cookie數(shù)據(jù)始終在同源的http請求中攜帶,而Storage不會(huì)在請求中攜帶,僅在本地存儲(chǔ)
    • 存儲(chǔ)大小上, cookie一般是4k,Storage可以達(dá)到5M-10M
    • 數(shù)據(jù)存儲(chǔ)時(shí)間上:sessionStorage僅僅是會(huì)話級別的存儲(chǔ),它只在當(dāng)前瀏覽器關(guān)閉前有效,不能持久保持;localStorage始終有效,即使窗口或?yàn)g覽器關(guān)閉也一直有效,除非用戶手動(dòng)刪除;cookie只在設(shè)定的 過期時(shí)間之前有效
    • 作用域上:sessionStorage不在不同的瀏覽器窗口中共享,即使是同一個(gè)頁面; localStorage和 cookie在所有同源窗口是共享的
    • Storage支持事件通知機(jī)制,可以將數(shù)據(jù)更新的通知發(fā)送給監(jiān)聽者。并且它提供增刪查api使用更方便

    24. 說說你做過的前端性能優(yōu)化(JS原生,React, vue)

    [參考答案] 參考周二打卡答案

    25. 對web安全的理解

    [參考答案]

    • CSRF 攻擊和防范

    跨站請求偽造,可以理解為攻擊者盜用了用戶的身份,以用戶的名義發(fā)送惡意請求,造成用戶隱私及財(cái)產(chǎn)損失 過程: 1.登錄受信任網(wǎng)站并在本地生成cookie; 2.在不登出 網(wǎng)站 的情況下訪問危險(xiǎn)網(wǎng)站 防范: 關(guān)鍵操作只接受POST請求, 使用驗(yàn)證碼, 檢測Referer, 使用token(或者JWT)

    • XSS 攻擊和防范

    全稱Cross-site script,跨站腳本攻擊,是Web程序中常見的漏洞。原理是攻擊者向有XSS漏洞的網(wǎng)站中輸入惡意的腳本,當(dāng)其它用戶瀏覽該網(wǎng)站時(shí)候,該腳本會(huì)自動(dòng)執(zhí)行,從而達(dá)到攻擊的目的(盜取Cookie,破壞頁面結(jié)構(gòu),重定向到釣魚網(wǎng)站等)。 區(qū)分: 分為持久型XSS和非持久性XSS. 持久型XSS是將攻擊的腳本植入到服務(wù)器,從而導(dǎo)致每個(gè)訪問的用戶都會(huì)遭到此XSS腳本的攻擊。非持久型XSS是將惡意腳本包裝在頁面的URL參數(shù)中,通過URL鏈接騙取用戶訪問,從而進(jìn)行攻擊. 防范: 對用戶輸入進(jìn)行HTML轉(zhuǎn)義, 對敏感信息進(jìn)行過濾

    • SQL 注入與防范

    通過把SQL命令插入到表單中并提交或頁面請求的參數(shù)中,最終使得服務(wù)器執(zhí)行惡意的SQL命令. 防范: 對用戶的輸入進(jìn)行校驗(yàn)或限制長度;對特殊字符進(jìn)行轉(zhuǎn)換, 不要使用動(dòng)態(tài)拼裝SQL,為每個(gè)應(yīng)用使用單獨(dú)的權(quán)限有限的數(shù)據(jù)庫連接。對隱私信息進(jìn)行加密

    • DDOS 攻擊

    分布式拒絕服務(wù)(DDoS:Distributed Denial of Service)攻擊指借助于客戶/服務(wù)器技術(shù),將多個(gè)計(jì)算機(jī)聯(lián)合起來作為攻擊平臺(tái),對一個(gè)或多個(gè)目標(biāo)發(fā)動(dòng)DDoS攻擊,從而成倍地提高拒絕服務(wù)攻擊的威力。

    26. 用js實(shí)現(xiàn)數(shù)組隨機(jī)取數(shù),每次返回的值都不一樣

    [參考答案]

    function getUniqueItems(arr, num) { let temp = []; for (let index in arr) { temp.push(arr[index]); } let res = []; for (let i = 0; i0) { let arrIndex = Math.floor(Math.random()*temp.length); res[i] = temp[arrIndex]; temp.splice(arrIndex, 1); } else { break; } } return res;}復(fù)制代碼

    27. 頁面上有1萬個(gè)button如何綁定事件

    [參考答案] 事件委托, 冒泡觸發(fā)

    28. base64為什么能提升性能以及它的缺點(diǎn)是什么

    [參考答案] 優(yōu)點(diǎn):

    • 無額外請求
    • 適用于很小或者很簡單的圖片
    • 可像單獨(dú)圖片一樣使用,比如背景圖片等
    • 沒有跨域問題,不需要考慮緩存、文件頭或者cookies問題 缺點(diǎn):
    • CSS 文件體積的增大, 造成CRP(關(guān)鍵渲染路徑)阻塞
    • 頁面解析CSS生成的CSSOM時(shí)間增加

    29. 介紹webp圖片文件格式

    [參考答案]

    WebP是一種支持有損壓縮和無損壓縮的圖片文件格式,根據(jù)Google的測試,無損壓縮后的WebP比PNG 文件少了45%的文件大小,即使這些PNG文件經(jīng)過其他壓縮工具壓縮之后,WebP 還是可以減少28%的文件大小。

    • 優(yōu)點(diǎn) 更小的文件尺寸 更高的質(zhì)量——與其他相同大小不同格式的壓縮圖像比較
    • 缺點(diǎn) 編碼和解碼速度比較慢,存在一定兼容性

    30. react-router里的Link標(biāo)簽和a標(biāo)簽有什么區(qū)別

    [參考答案]

    從渲染的DOM來看,這兩者都是鏈接,都是a標(biāo)簽,區(qū)別是: Link是react-router里實(shí)現(xiàn)路由跳轉(zhuǎn)的鏈接,配合Route使用,react-router攔截了其默認(rèn)的鏈接跳轉(zhuǎn)行為,區(qū)別于傳統(tǒng)的頁面跳轉(zhuǎn),Link 的“跳轉(zhuǎn)”行為只會(huì)觸發(fā)相匹配的Route對應(yīng)的頁面內(nèi)容更新,而不會(huì)刷新整個(gè)頁面。 a標(biāo)簽是html原生的超鏈接,用于跳轉(zhuǎn)到href指向的另一個(gè)頁面或者錨點(diǎn)元素,跳轉(zhuǎn)新頁面會(huì)刷新頁面。

    31. 介紹一下函數(shù)柯里化,并寫一個(gè)柯里化函數(shù)

    [參考答案]

    柯里化是一種將使用多個(gè)參數(shù)的一個(gè)函數(shù)轉(zhuǎn)換成一系列使用一個(gè)參數(shù)的函數(shù)的技術(shù)。柯里化函數(shù)能夠讓我們:

  • 在多個(gè)函數(shù)調(diào)用中依次收集參數(shù),不用在一個(gè)函數(shù)調(diào)用中收集所有參數(shù)。
  • 當(dāng)收集到足夠的參數(shù)時(shí),返回函數(shù)執(zhí)行結(jié)果。
  • 32. 介紹一下從輸入U(xiǎn)RL到頁面加載全過程

    [參考答案]

    • 瀏覽器的地址欄輸入U(xiǎn)RL并按下回車。
    • 瀏覽器查找當(dāng)前URL是否存在緩存,并比較緩存是否過期。
    • DNS解析URL對應(yīng)的IP。
    • 根據(jù)IP建立TCP連接(三次握手)。
    • HTTP發(fā)起請求。
    • 服務(wù)器處理請求,瀏覽器接收HTTP響應(yīng)。
    • 渲染頁面,構(gòu)建DOM樹。
    • 關(guān)閉TCP連接(四次揮手)。

    33. 說說bind、call、apply的區(qū)別

    [參考答案]

    call和apply的共同點(diǎn)
    • 都能夠改變函數(shù)執(zhí)行時(shí)的上下文,將一個(gè)對象的方法交給另一個(gè)對象來執(zhí)行,并且是立即執(zhí)行的
    • 調(diào)用call和apply的對象,必須是一個(gè)函數(shù)Function
    call和apply的區(qū)別
    • apply的第二個(gè)參數(shù),必須是數(shù)組或者類數(shù)組,它會(huì)被轉(zhuǎn)換成類數(shù)組,傳入函數(shù)中,并且會(huì)被映射到函數(shù)對應(yīng)的參數(shù)上, 而call從第二個(gè)參數(shù)開始,可以接收任意個(gè)參數(shù)
    bind
    • bind()方法創(chuàng)建一個(gè)新的函數(shù),與apply和call比較類似,也能改變函數(shù)體內(nèi)的this指向。不同的是,bind方法的返回值是函數(shù),并且需要稍后調(diào)用,才會(huì)執(zhí)行。而apply和call 則是立即調(diào)用

    34. ES6中的map和原生的對象有什么區(qū)別

    [參考答案]

    object和Map存儲(chǔ)的都是鍵值對組合。區(qū)別:object的鍵的類型是字符串;map的鍵的類型可以是任意類型;另外,object獲取鍵值使用Object.keys(返回?cái)?shù)組)Map獲取鍵值使用map變量.keys() (返回迭代器)。

    35. 說說H5手機(jī)端的適配的幾種方案

    [參考答案]

    • js實(shí)現(xiàn)一
    (function (doc, win) { var docEl = doc.documentElement, resizeEvt = 'orientationchange' in window ? 'orientationchange' : 'resize', recalc = function () { var clientWidth = docEl.clientWidth; var fontSize = 20; docEl.style.fontSize = fontSize + 'px'; var docStyles = getComputedStyle(docEl); var realFontSize = parseFloat(docStyles.fontSize); var scale = realFontSize / fontSize; console.log("realFontSize: " + realFontSize + ", scale: " + scale); fontSize = clientWidth / 750 * 20; if(isIphoneX()) fontSize = 19; fontSize = fontSize / scale; docEl.style.fontSize = fontSize + 'px'; }; // Abort if browser does not support addEventListener if (!doc.addEventListener) return; win.addEventListener(resizeEvt, recalc, false); doc.addEventListener('DOMContentLoaded', recalc, false); // iphoneX判斷 function isIphoneX(){ return /iphone/gi.test(navigator.userAgent) && (screen.height == 812 && screen.width == 375) }})(document, window);復(fù)制代碼
    • css @media媒介查詢(蘇寧易購實(shí)現(xiàn)方式)
    • 手淘的lib-flexible實(shí)現(xiàn)方式

    36. 用js如何去除url中的#號

    [參考答案]

    • 情景一: 單純將hash路由改變成history路由即可去除hash的#號,此時(shí)需要服務(wù)器做路由重定向,比如nginx, node重定向
    • 情景二: 單純?nèi)コ?
    function dropHash(url) { let i = url.indexOf('#') return i > -1 ? url.replace(/#/g, '') : url}復(fù)制代碼

    37. Redux狀態(tài)管理器和變量掛載到window中有什么區(qū)別

    [參考答案] redux通過制定一套嚴(yán)格的規(guī)范,提供一種規(guī)范式的api和使用方式來處理狀態(tài), 適合大型項(xiàng)目和多人協(xié)同開發(fā)的項(xiàng)目,雖然代碼編寫有些繁復(fù),但整體數(shù)據(jù)流向清楚,便于問題跟蹤和后期維護(hù),并且支持狀態(tài)回溯.而window的變量管理比較混亂,維護(hù)不當(dāng)還會(huì)造成變量污染,不適合中大型項(xiàng)目的開發(fā).

    38. webpack和gulp的優(yōu)缺點(diǎn)

    [參考答案]

    gulp webpack 定位 基于任務(wù)流的自動(dòng)化打包工具 模塊化打包工具 優(yōu)點(diǎn) 易于學(xué)習(xí)和理解, 適合多頁面應(yīng)用開發(fā) 可以模塊化的打包任何資源,適配任何模塊系統(tǒng),適合SPA單頁應(yīng)用的開發(fā) 缺點(diǎn) 不太適合單頁或者自定義模塊的開發(fā) 學(xué)習(xí)成本低,配置復(fù)雜,通過babel編譯后的js代碼打包后體積過大

    39. 說說jsonp為什么不支持post方法

    [參考答案]

    瀏覽器的同源策略限制從一個(gè)源加載的文檔或腳本與來自另一個(gè)源的資源進(jìn)行交互,jsonp跨域本質(zhì)上是通過動(dòng)態(tài)script標(biāo)簽, 本質(zhì)上也是對靜態(tài)資源的訪問,所以只能是get請求

    40. 說說棧和堆的區(qū)別, 垃圾回收時(shí)棧和堆的區(qū)別以及棧和堆具體怎么存儲(chǔ)

    [參考答案]

    1.從定義和存取方式上說:

    • 棧stack為自動(dòng)分配的內(nèi)存空間, 它由系統(tǒng)自動(dòng)釋放, 特點(diǎn)是"LIFO,即后進(jìn)先出(Last in, first out)"。數(shù)據(jù)存儲(chǔ)時(shí)只能從頂部逐個(gè)存入,取出時(shí)也需從頂部逐個(gè)取出,js的基本數(shù)據(jù)類型(Undefined、Null、Boolean、Number和String). 基本類型在內(nèi)存中占據(jù)空間小、大小固定 ,他們的值保存在棧空間,按值訪問
    • 對heap是動(dòng)態(tài)分配的內(nèi)存,大小不定也不會(huì)自動(dòng)釋放. 特點(diǎn)是"無序"的key-value"鍵值對"存儲(chǔ)方式. 比如js的對象,數(shù)組. 引用類型占據(jù)空間大、大小不固定, 棧內(nèi)存中存放地址指向堆(heap)內(nèi)存中的對象。是按引用訪問的

    2.從js數(shù)據(jù)的存取過程上說:

    棧內(nèi)存中存放的是對象的訪問地址,在堆內(nèi)存中為這個(gè)值分配空間。這個(gè)值大小不固定,因此不能把它們保存到棧內(nèi)存中。但內(nèi)存地址大小的固定的,因此可以將內(nèi)存地址保存在棧內(nèi)存中。這樣,當(dāng)查詢引用類型的變量時(shí),先從棧中讀取內(nèi)存地址,然后再通過地址找到堆中的值。

    3.棧內(nèi)存和堆內(nèi)存與垃圾回收機(jī)制的聯(lián)系和清除方式:

    • 垃圾回收機(jī)制: JavaScript中有自動(dòng)垃圾回收機(jī)制,會(huì)通過標(biāo)記清除的算法識(shí)別哪些變量對象不再使用,對其進(jìn)行銷毀。開發(fā)者也可在代碼中手動(dòng)設(shè)置變量值為null(xxx = null)進(jìn)行清除,讓引用鏈斷開,以便下一次垃圾回收時(shí)有效回收。其次, 函數(shù)執(zhí)行完成后,函數(shù)局部環(huán)境聲明的變量不再需要時(shí),就會(huì)被垃圾回收銷毀(理想的情況下,閉包會(huì)阻止這一過程)。全局環(huán)境只有頁面退出時(shí)才會(huì)出棧,解除變量引用。所以工程師們應(yīng)盡量避免在全局環(huán)境中創(chuàng)建全局變量,如需使用,一定要在不需要時(shí)手動(dòng)標(biāo)記清除,將內(nèi)存釋放。
    • 棧內(nèi)存和堆內(nèi)存通常與垃圾回收機(jī)制有關(guān)。之所以會(huì)區(qū)分棧內(nèi)存和堆內(nèi)存,目的是使程序運(yùn)行時(shí)占用的內(nèi)存最小。當(dāng)某個(gè)方法執(zhí)行時(shí),都會(huì)建立自己的內(nèi)存棧,在這個(gè)方法內(nèi)定義的變量將會(huì)逐個(gè)放入棧內(nèi)存里,隨著方法的執(zhí)行結(jié)束,這個(gè)方法的內(nèi)存棧也將自然銷毀了。因此,所有在方法中定義的變量都是放在棧內(nèi)存中的;當(dāng)我們創(chuàng)建一個(gè)對象時(shí),對象會(huì)被保存到運(yùn)行時(shí)數(shù)據(jù)區(qū)中,以便反復(fù)利用(因?yàn)閷ο蟮膭?chuàng)建內(nèi)存開銷較大),這個(gè)運(yùn)行時(shí)數(shù)據(jù)區(qū)就是堆內(nèi)存。堆內(nèi)存中的對象不會(huì)隨方法的結(jié)束而銷毀,即使方法結(jié)束后,這個(gè)對象還可能被另一個(gè)引用變量所引用,則這個(gè)對象依然不會(huì)被銷毀,只有當(dāng)一個(gè)對象沒有任何引用變量引用它時(shí),系統(tǒng)的垃圾回收機(jī)制才會(huì)在循環(huán)收集的過程中回收。

    41. ES6中l(wèi)et塊作用域是怎么實(shí)現(xiàn)的

    [參考答案]

    可以通過閉包自執(zhí)行函數(shù)實(shí)現(xiàn)塊作用域

    42. 介紹排序算法和快排原理

    [參考答案]

    排序算法有:冒泡排序, 希爾排序, 快速排序, 插入排序, 歸并排序, 堆排序, 桶排序等.

    快速排序原理:

    通過一趟排序?qū)⒁判虻臄?shù)據(jù)分割成獨(dú)立的兩部分,其中一部分的所有數(shù)據(jù)都比另外一部分的所有數(shù)據(jù)都要小,然后再按此方法對這兩部分?jǐn)?shù)據(jù)分別進(jìn)行快速排序,整個(gè)排序過程可以遞歸進(jìn)行,以此達(dá)到整個(gè)數(shù)據(jù)變成有序序列。

    43. 說說node文件查找的優(yōu)先級

    [參考答案] 從文件模塊緩存中加載 > 從原生模塊加載 > 從文件加載

    44. WebView和原生是如何通信的

    [參考答案]

    • 使用Android原生的JavascriptInterface來進(jìn)行js和java的通信
    • UrlRouter(通過內(nèi)部實(shí)現(xiàn)的框架去攔截前端寫的url,如果符合UrlRouter的協(xié)議的話,就執(zhí)行相應(yīng)的邏輯)
    • WebView 中的 prompt/console/alert 攔截,通常使用 prompt避免副作用
    • API注入,通過Native獲取JavaScript環(huán)境上下文,并直接在上面添加方法,使js可以直接調(diào)用

    45. pm2怎么做進(jìn)程管理,如何解決進(jìn)程崩潰問題

    [參考答案]

    • 通過pm2 start去開啟一個(gè)進(jìn)程, pm2 stop去停止某個(gè)進(jìn)程, pm2 list去查看進(jìn)程列表, pm2 monit查看每個(gè)進(jìn)程的cpu使用情況, pm2 restart重啟指定應(yīng)用等
    • 進(jìn)程奔潰可以用過設(shè)置自動(dòng)重啟或者限制應(yīng)用運(yùn)行內(nèi)存max_memory_restart(最大內(nèi)存限制數(shù),超出自動(dòng)重啟)

    46. 直接給一個(gè)數(shù)組項(xiàng)賦值,Vue 能檢測到變化嗎,為什么?

    [參考答案] vue中的數(shù)組的監(jiān)聽不是通過Object.defineProperty來實(shí)現(xiàn)的,是通過對'push', 'pop','shift','unshift','splice', 'sort','reverse'等改變數(shù)組本身的方法來通知監(jiān)聽的,所以直接給數(shù)組某一項(xiàng)賦值無法監(jiān)聽到變化,解決方案如下:

    • 用vue的set方法改變數(shù)組或者對象
    • 用改變數(shù)組本身的方法如splice, pop, shift等
    • 用深拷貝,解構(gòu)運(yùn)算符

    總結(jié)

    面試只是進(jìn)入公司的第一步,如何走好它,需要自身的不斷努力和學(xué)習(xí),所以不要沉迷于走捷徑,踏踏實(shí)實(shí)的學(xué)技術(shù)吧. 年前筆者會(huì)總結(jié)一下筆者2019年的技術(shù)成長與規(guī)劃, 希望能和大家繼續(xù)分享真正的前端技術(shù).

    最后

    如果想了解更多H5游戲, webpacknodegulpcss3javascriptnodeJScanvas數(shù)據(jù)可視化等前端知識(shí)和實(shí)戰(zhàn),歡迎在《趣談前端》學(xué)習(xí)討論,共同探索前端的邊界。

    總結(jié)

    以上是生活随笔為你收集整理的promise的状态以及api介绍_2019年,盘点一些我出过的前端面试题以及对求职者的建议的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。

    日韩欧美国产免费播放 | av在线一级 | 日韩69av | 精品1区2区3区 | 日韩高清免费无专码区 | 欧美亚洲精品在线观看 | 一区二区三区手机在线观看 | 中文字幕影片免费在线观看 | 欧美日韩国产一区二区三区在线观看 | 高清免费av在线 | 日本视频高清 | 国内久久久久久 | 色婷婷国产精品一区在线观看 | 欧洲不卡av| 久久久国产99久久国产一 | 91av免费在线观看 | 伊人久在线| 午夜999 | 黄色一级大片免费看 | 午夜私人影院 | 婷婷丁香在线观看 | 欧美精品久久久久久久久老牛影院 | 国产手机视频 | 久久精品国产免费看久久精品 | 精品国产伦一区二区三区观看说明 | 国产精品久久久久免费a∨ 欧美一级性生活片 | 操操日| 国产精品成人久久 | 免费性网站 | 97超碰超碰久久福利超碰 | 久久一区二区三区国产精品 | 热久久国产精品 | 日韩毛片久久久 | 中文字幕中文中文字幕 | 91亚洲激情 | av888av.com| 91亚洲国产成人 | 亚洲成人一二三 | 在线免费观看黄色大片 | 日本中文字幕网站 | 国产精品欧美久久久久无广告 | 91精品国产亚洲 | 免费高清影视 | 国产精品系列在线 | 五月天激情在线 | 九九热在线精品视频 | 国内精品久久久久久久影视简单 | 日韩欧美高清一区二区三区 | 欧美xxxx性xxxxx高清 | 久久经典国产视频 | 久久国色夜色精品国产 | 国产成人精品一区二区三区在线观看 | 一级黄色免费 | 97在线视频网站 | 不卡的av在线播放 | av丝袜美腿 | 色婷婷激婷婷情综天天 | 国产精品视频永久免费播放 | 五月开心婷婷网 | 亚洲成人av在线播放 | 国产一区在线免费观看视频 | 亚洲一级免费电影 | 69精品在线 | 色偷偷中文字幕 | 亚洲不卡在线 | 国产精品免费一区二区三区在线观看 | 成人国产综合 | 91精品国产电影 | 91精品久久久久久综合乱菊 | 久久不射电影院 | 激情av网 | 国产日韩亚洲 | 一本一道久久a久久精品蜜桃 | 91精品啪啪 | 国产一区二区免费在线观看 | 欧美一区二区精美视频 | 国产成人资源 | 日日夜夜网站 | 99c视频在线 | 久久免费视频这里只有精品 | 探花在线观看 | 99久久成人 | 久久久久综合网 | 青春草免费在线视频 | 久久综合操 | 福利一区视频 | 六月色婷 | 久久精品亚洲一区二区三区观看模式 | 麻豆精品视频在线观看免费 | 国产精品中文字幕在线 | 国产黄在线 | 成人免费视频免费观看 | 91视频免费 | 国产1区2区3区精品美女 | 成年人在线观看网站 | 国产精品久久久久免费a∨ 欧美一级性生活片 | 亚洲高清激情 | 成年人视频在线免费 | 亚洲性xxxx | 国产成人精品午夜在线播放 | 日韩一区在线播放 | 中文字幕在线观看视频一区二区三区 | 手机看片 | 国产成人精品国内自产拍免费看 | 欧美午夜寂寞影院 | 国产欧美最新羞羞视频在线观看 | 日韩成人邪恶影片 | 中文字幕视频免费观看 | 999国内精品永久免费视频 | 日韩精品视频免费在线观看 | 午夜av免费观看 | 麻豆免费看片 | av免费看在线 | 91在线小视频 | 最新午夜 | 久久久久夜色 | 久久综合欧美精品亚洲一区 | 激情网色 | 狠狠色丁香婷婷综合 | 国产做爰视频 | 国产亚洲va综合人人澡精品 | 欧美怡红院视频 | 最近中文字幕高清字幕免费mv | 久久国产成人午夜av影院潦草 | 天天草天天色 | 日韩av免费大片 | 色偷偷av男人天堂 | 久久97超碰 | 国产91免费在线 | 激情婷婷六月 | 国产亚洲一级高清 | 精品久久久久久久久亚洲 | 六月丁香在线观看 | 国产精品一区二区吃奶在线观看 | 精品在线观看一区二区 | 国产精品成人在线 | 丁香婷五月 | 天天色天天操天天爽 | 久久国产香蕉视频 | 久久99国产精品免费网站 | 国产精品入口麻豆www | 人人超碰免费 | 久久久www成人免费精品张筱雨 | 久久免费视频一区 | 黄色小说在线免费观看 | 91人人爽人人爽人人精88v | 天天天操操操 | 九色91在线 | 99午夜| 日韩在线观看a | 欧美日韩不卡一区二区 | 成人在线观看网址 | 六月色丁香| 97电影院在线观看 | 99在线热播精品免费99热 | 亚洲精品在线观看av | 激情五月网站 | 91色亚洲 | 久久a级片 | 日韩精品一区在线播放 | 欧美精品一区二区免费 | 久久伦理 | 在线中文日韩 | 国产丝袜制服在线 | 久久激情久久 | 最近日本字幕mv免费观看在线 | 欧美成人91 | av电影免费在线播放 | 精品久久久免费 | 99久久99久久综合 | 99热都是精品 | 色欲综合视频天天天 | 日本三级香港三级人妇99 | www.888.av| 天堂av在线免费观看 | 91精品久久香蕉国产线看观看 | 精品国产三级a∨在线欧美 免费一级片在线观看 | 狠狠色噜噜狠狠狠狠2021天天 | 少妇视频在线播放 | 免费色视频网址 | 成人a免费 | 性色av免费观看 | 久久激情综合网 | 99久久精品国产系列 | 高清av免费看 | 亚洲美女视频在线观看 | 久久伦理视频 | 天天操天天操天天操 | 中中文字幕av在线 | 91最新网址在线观看 | 丁香花中文字幕 | 四虎在线视频免费观看 | 成人免费视频a | 在线观看日本韩国电影 | 欧美在线观看视频免费 | 欧美一区二区精美视频 | 久久久免费播放 | 久久a久久| 狠狠色伊人亚洲综合网站野外 | 久久高清av | 久久国产热视频 | 欧美日韩在线看 | 91免费高清| 久久精品视频日本 | 免费日韩电影 | 国产精品网在线观看 | 欧美日韩色婷婷 | 色婷婷av在线 | 日韩精品在线免费播放 | 亚洲高清在线视频 | 天天操天天爱天天干 | 亚洲小视频在线 | 国产中的精品av小宝探花 | 91久久精 | 青青河边草免费直播 | 色爱成人网| 99久久综合国产精品二区 | 精品视频在线观看 | 九九热久久免费视频 | 国产色拍 | 成年人免费在线 | 国产xxxx性hd极品 | 激情网婷婷 | 色综合久久精品 | 久久激情网站 | 这里只有精品视频在线 | 日韩中字在线观看 | 中文字幕免费观看视频 | 国语对白少妇爽91 | 免费黄色特级片 | 久久免费视频7 | 精品久久久久久久久中文字幕 | 免费欧美精品 | 日女人电影 | 午夜骚影 | 久久久久国产一区二区 | 国产精品久久久久久久久久免费看 | 黄色精品视频 | 日韩黄色大片在线观看 | 日本福利视频在线 | 亚洲成人黄色在线观看 | 91视频在线播放视频 | 99视频一区二区 | 中文字幕 国产 一区 | 亚洲精品乱码久久久久久蜜桃不爽 | 91正在播放 | 日韩在线观看视频中文字幕 | 国产视频九色蝌蚪 | 亚洲精品视频在线免费播放 | 国内久久久久久 | 99久久精品国产亚洲 | 国产精品门事件 | 国产亚洲视频中文字幕视频 | 在线观看www视频 | 日韩r级电影在线观看 | 午夜精品一区二区三区免费 | 福利久久久 | 国产久草在线 | 欧美成年人在线视频 | 国产高清黄色 | 国产不卡在线看 | 99精品一区二区 | 日韩高清一二区 | 免费久久网 | 天天·日日日干 | 色综合久久综合中文综合网 | 成人黄色大片在线免费观看 | 国产精品免费人成网站 | 97视频在线观看视频免费视频 | 91黄色影视| 日日夜夜狠狠干 | 五月综合在线观看 | 欧美日韩国产综合一区二区 | av免费电影网站 | 国产美女精彩久久 | 激情大尺度视频 | 国产一区二区不卡视频 | 一区二区三区中文字幕在线 | 欧美日韩国产精品爽爽 | 天天干,天天射,天天操,天天摸 | 国产精品久久久久婷婷 | 亚洲精品电影在线 | 丁香六月综合网 | 在线国产片 | 在线视频日韩 | 国产又粗又硬又爽视频 | 欧美精品久久天天躁 | 夜夜夜精品| 91热精品 | 亚洲欧美观看 | 欧美大片在线看免费观看 | 日日夜夜综合 | 亚洲国产视频直播 | 香蕉视频国产在线观看 | 操操操综合 | 久久久五月婷婷 | 国产高清亚洲 | 超碰在线资源 | 视频在线99re | 天天操天天射天天爱 | 亚洲精品伦理在线 | 丁香六月在线观看 | 久久精品视频网站 | 久久久精品网 | 国产日韩一区在线 | avwww在线观看 | 伊甸园av在线| 亚洲精品永久免费视频 | 蜜桃视频日本 | 国产精品一区二区av影院萌芽 | 91精品国产91热久久久做人人 | 婷婷综合伊人 | 婷香五月 | 免费看91的网站 | 天天射天天色天天干 | 免费精品久久久 | 尤物97国产精品久久精品国产 | 香蕉视频在线免费看 | 2021av在线| 国产中文视频 | 久久精品成人 | 66av99精品福利视频在线 | 91香蕉国产 | 808电影| 99re8这里有精品热视频免费 | 日韩精品中文字幕一区二区 | 在线观看你懂的网址 | 久久99在线 | 香蕉在线观看视频 | 免费韩国av | 五月婷婷丁香网 | 日韩欧美在线视频一区二区三区 | 91日韩在线专区 | 国产中文在线播放 | 国产精品一区二区免费在线观看 | 丁香六月色 | 国产我不卡 | 中文字幕无吗 | 一区二区三区 中文字幕 | 免费观看mv大片高清 | 狠狠的日| 欧美性色19p | 日韩在线中文字幕视频 | 一区二区三区四区精品视频 | 欧美日韩精品久久久 | 黄色一级动作片 | 国产精品视频不卡 | 天天天干 | 国产精品一区二区三区在线免费观看 | 国产在线观看黄 | 欧美精品久久久久久久久久 | 看国产黄色片 | 免费国产在线精品 | 国产视频一区在线播放 | 成人av网址大全 | 日本在线h| 国产精品久久亚洲 | 免费在线观看国产黄 | 最近久乱中文字幕 | 欧美永久视频 | 国产一区二区三区网站 | 国产精品成人一区二区 | 久久久国产在线视频 | 日本三级吹潮在线 | 91av福利视频 | 亚州激情视频 | 欧美一区二区在线看 | 国产专区在线 | 国产成人不卡 | 亚洲精品女| 男女视频久久久 | 日韩综合视频在线观看 | 亚洲区色| 国产精品video爽爽爽爽 | 8x成人免费视频 | 久久久久 免费视频 | 亚洲国产日韩欧美在线 | 中文字幕在线观看完整版 | 国产精品久久久亚洲 | 亚洲美女视频在线观看 | 免费的黄色av | 中文字幕在线看视频 | 国内精自线一二区永久 | 免费看的黄色的网站 | 国产精品亚洲精品 | 婷婷色吧 | 超碰国产在线播放 | 午夜av在线播放 | 国产手机视频在线 | 国产淫片免费看 | 又黄又爽的免费高潮视频 | 欧美日韩不卡一区二区三区 | 国产精品久久久久久久久久新婚 | 在线观看av免费 | 国产精品九九九九九 | 国产免费人人看 | 热久久视久久精品18亚洲精品 | 久久久亚洲国产精品麻豆综合天堂 | 成人观看视频 | 中文字幕乱码日本亚洲一区二区 | 香蕉日日 | 黄色av一级片 | 日韩国产精品一区 | 欧洲精品久久久久毛片完整版 | 久久不射网站 | 精品视频99 | 久久久久伊人 | 欧美精品一区二区三区四区在线 | 国产第一页精品 | 日韩精品一区二区三区免费视频观看 | 国产伦理久久精品久久久久_ | 精品久久久久一区二区国产 | 丰满少妇在线观看资源站 | 免费午夜视频在线观看 | 国产精品久久久久一区二区国产 | 成人免费av电影 | 91视频免费播放 | 中文字幕999 | 美女av免费看 | 亚洲成人999 | 精品福利视频在线观看 | 91丨porny丨九色| 亚洲狠狠操 | 久久国产二区 | 欧美久久久久久久 | 一本一道久久a久久精品 | 97视频久久久 | 在线观看一区视频 | 国产免费观看视频 | 国产精品普通话 | 天天草综合网 | 麻豆一区在线观看 | 国产一区二区中文字幕 | 国产午夜精品福利视频 | 91丨九色丨高潮 | 亚洲综合欧美精品电影 | 日韩久久在线 | 黄色网www | 胖bbbb搡bbbb擦bbbb | 亚洲免费高清视频 | 国产一区视频在线播放 | 婷婷色网视频在线播放 | 久操中文字幕在线观看 | 日韩在线免费视频 | 久久精品一二区 | 日韩免费一二三区 | 成人资源网 | 日韩精品一区二区三区免费视频观看 | 狠狠狠狠狠干 | 婷婷深爱| 麻豆免费观看视频 | 国产91精品一区二区麻豆网站 | 日韩在线 一区二区 | 亚洲精品高清在线观看 | 欧美日韩国产一二三区 | 欧美视频国产视频 | www麻豆视频 | 久久精品屋| 国产色婷婷| 日韩精品一区二区久久 | 国产手机在线观看 | 99久久精品免费看国产免费软件 | 狠狠插狠狠干 | 伊人热 | 99视频免费观看 | 久久se视频 | 四虎国产精品成人免费4hu | 日韩一二区在线 | 一级片免费观看 | 国产精品久久久久久av | 成人黄色小说视频 | 久草视频在线资源站 | 99九九免费视频 | 亚洲精品乱码久久久久久久久久 | 国产高清av免费在线观看 | 麻豆视频在线免费看 | 在线免费视频一区 | 五月天网页| 久精品视频在线观看 | 中国一级片免费看 | 日本中文字幕在线观看 | 丝袜制服综合网 | 亚洲精品tv久久久久久久久久 | 国产一级片不卡 | 欧美精品在线观看免费 | 91在线精品播放 | 日韩免费| 菠萝菠萝蜜在线播放 | 91字幕| 午夜精品久久久久久 | 久久久激情网 | 91亚洲国产成人久久精品网站 | 亚洲国产一区二区精品专区 | 69久久99精品久久久久婷婷 | 在线免费观看成人 | 狠狠综合 | 久久综合久久综合这里只有精品 | 91看片淫黄大片在线播放 | 欧美a级成人淫片免费看 | 成年一级片| 久久久久久蜜av免费网站 | 国产精品成人自拍 | 2021av在线| 天天添夜夜操 | 精品国产区 | 亚洲第一成网站 | 国产色久| 久久久久久久影视 | 国产特级毛片aaaaaa高清 | 99热超碰在线 | av网站地址 | 久久 亚洲视频 | 日韩黄色av网站 | 天堂av在线网 | 国产高清成人av | 国产成人精品不卡 | av免费电影网站 | 一区 二区电影免费在线观看 | 黄色91在线 | 久久1电影院 | 日韩高清www| 成人在线视频免费看 | 久久黄色免费视频 | 日日干日日 | 中文字幕国产一区 | 中文字幕免费高清av | 国产婷婷一区二区 | 国产成人精品一区二 | 日日夜夜狠狠操 | 91精品在线免费观看 | 六月丁香婷婷网 | 免费色视频网址 | 精品视频资源站 | 99亚洲国产精品 | 97人人澡人人爽人人模亚洲 | 久久综合久久综合这里只有精品 | 91精品黄色 | 最新中文字幕在线播放 | 五月综合婷 | 成人国产精品免费观看 | 天天爽天天碰狠狠添 | 九九在线精品视频 | 成人av网页| 黄色亚洲在线 | 麻豆成人在线观看 | 最新av网址在线观看 | 91在线免费观看国产 | 69av在线播放 | 日韩欧美在线综合网 | 亚洲理论片 | 国产精品久久久久久久久久东京 | 久久精品99北条麻妃 | 99精品区| 91午夜精品 | 狠狠地日 | 911精品视频 | 99re6热在线精品视频 | 色多多视频在线观看 | 国产96精品 | 国产视频亚洲视频 | 日韩一级电影在线 | 日本午夜免费福利视频 | 欧美亚洲xxx| 99久久久久国产精品免费 | 日日干日日 | 欧美一级性 | 黄色成人小视频 | 亚洲人毛片 | 久草资源在线观看 | 成人电影毛片 | 99爱视频 | 一区中文字幕 | 99精品在线| 四虎国产精品永久在线国在线 | 国产97在线观看 | 久久综合五月天 | 亚洲成av人影院 | 超碰在线最新网址 | 91成人免费视频 | 欧美日本一二三 | 波多野结衣动态图 | 欧美激情亚洲综合 | 久久兔费看a级 | 国产精品二区在线 | 国产精品久久久久av | 日韩r级在线 | 国产精品美女www爽爽爽视频 | 国产一区高清在线观看 | 精品久久国产精品 | 久久精品影片 | 成人av手机在线 | 国产视频一区二区在线播放 | 九九三级毛片 | av免费电影在线观看 | 国产又粗又猛又黄 | 四虎在线视频 | 欧美一区二区免费在线观看 | 午夜影视剧场 | 午夜免费久久看 | 99久久成人 | 97视频人人澡人人爽 | 九九一级片 | 欧美在线1 | av亚洲产国偷v产偷v自拍小说 | www婷婷| 亚洲第一区在线观看 | av爱干 | 国产精品99久久久久久有的能看 | 欧美一级大片在线观看 | a天堂免费 | 不卡av电影在线 | 国产一级久久 | 中文字幕 在线看 | 日日久视频 | 香蕉视频国产在线 | 91精品国自产在线偷拍蜜桃 | 91人人爱| 一区二区成人国产精品 | 丁香视频五月 | 毛片激情永久免费 | 久久久999免费视频 日韩网站在线 | 在线看福利av | 丁香五月亚洲综合在线 | 中文字幕一区二区三区在线视频 | 麻豆免费视频观看 | 国产一级免费观看视频 | 伊人资源站 | 99精品在线视频观看 | 狠狠色噜噜狠狠狠狠 | av福利第一导航 | 免费亚洲婷婷 | 国产精品1区 | 久久99精品视频 | 欧美成人精品欧美一级乱黄 | 美女国产免费 | 国产精品1区 | 97在线公开视频 | 欧美日韩精品影院 | 中文字幕在线视频免费播放 | 色综合久久天天 | 免费视频一区 | 高清av免费观看 | 91激情| 中文字幕首页 | 久精品视频免费观看2 | 国产精品2020| 亚洲一级影院 | 91精品久久久久久综合五月天 | 天天色天天干天天色 | 日韩av成人免费看 | 亚洲欧美日韩精品久久久 | 日韩中文字幕免费在线播放 | 九九有精品 | 91在线看网站 | 91传媒免费在线观看 | www国产在线 | 狠狠干婷婷色 | 欧美精品中文字幕亚洲专区 | 国产精品国产三级国产aⅴ9色 | 中中文字幕av | 精品在线免费观看 | 亚洲狠狠 | 五月香视频在线观看 | 一级黄色a视频 | 亚洲国产精品视频在线观看 | 黄色毛片观看 | 久久久久国产精品一区二区 | 中文字幕在线不卡国产视频 | 国产福利精品视频 | 亚洲理论片在线观看 | 午夜电影久久 | 天天干夜夜想 | 国产字幕在线看 | 免费高清在线视频一区· | 人人爽人人爽人人片av免 | 国产一区二区三区免费观看视频 | 91精品在线播放 | 中文字幕在线视频一区二区三区 | 色播五月激情综合网 | 男女啪啪视屏 | 精品国产视频在线观看 | avv天堂| 精品在线视频一区二区三区 | 在线观看国产永久免费视频 | 亚洲精品久久视频 | 91av原创| 成人国产精品久久久久久亚洲 | 日韩在线观看的 | 国产精品女教师 | 国产精品aⅴ| 尤物一区二区三区 | 中文字幕中文字幕在线中文字幕三区 | 波多野结衣一区二区 | 九九视频热 | 国产精品岛国久久久久久久久红粉 | 欧美资源 | 中文字幕国产精品 | 婷婷av网 | 欧美性极品xxxx做受 | 国产 欧美 日产久久 | 91探花系列在线播放 | 午夜免费视频网站 | 99在线热播 | 成人av电影在线观看 | 91亚洲成人 | 欧美网址在线观看 | 国产一区二区视频在线播放 | 天天色天天骑天天射 | 天天爽夜夜爽人人爽一区二区 | sesese图片| 最近免费中文字幕mv在线视频3 | 99久久久国产免费 | 国产日韩精品视频 | 日韩av不卡在线观看 | 国产精品永久在线观看 | 99在线精品视频在线观看 | 日本久久成人中文字幕电影 | 黄色一级在线免费观看 | 日韩av综合网站 | 国产精品久久久久久久久久久久冷 | a天堂最新版中文在线地址 久久99久久精品国产 | 97在线观看免费观看 | 日韩中文字幕免费在线观看 | 九九九九免费视频 | 日韩精品无码一区二区三区 | 免费福利视频网站 | 色狠狠一区二区 | 高潮久久久久久久久 | 白丝av免费观看 | 久久精品国产免费看久久精品 | 日韩久久午夜一级啪啪 | 91人人人 | 久久这里只有精品视频首页 | 人人爽影院 | 在线观看日韩免费视频 | 亚洲六月丁香色婷婷综合久久 | www免费 | 欧洲精品码一区二区三区免费看 | 亚洲国内精品在线 | 99热这里只有精品8 久久综合毛片 | 黄色成年片 | 玖玖视频网 | 欧美一区二区三区免费看 | 成人黄在线 | 成人一级免费电影 | 日日操天天操狠狠操 | 成年人在线免费视频观看 | 一区二区影院 | 天天天天爽 | 久久国产福利 | 久久99最新地址 | 欧美激情视频免费看 | 国产69精品久久久久99 | 久久视频国产精品免费视频在线 | 国产精品一区在线播放 | 黄色日视频 | 91最新国产 | 欧美午夜精品久久久久 | 91成人精品一区在线播放69 | 视频在线国产 | 久久久久久久av | 99精品在线播放 | 西西444www大胆高清视频 | 最新极品jizzhd欧美 | 久久草网 | 亚洲天堂在线观看完整版 | 亚洲国内精品视频 | 久久九九视频 | 日本精品在线看 | 在线一二区 | 日韩av在线网站 | 国产在线p | 最新中文字幕视频 | 色在线视频| 久久久久久美女 | 亚洲年轻女教师毛茸茸 | 久久在线观看 | 人人爽人人爽人人片 | 成人国产精品久久久久久亚洲 | 亚洲欧美色婷婷 | 国产精品久久久久三级 | 欧美日韩高清一区二区 | 国产日韩视频在线 | 韩国精品福利一区二区三区 | 成人性生交视频 | 91色国产在线 | 免费视频 三区 | 2022中文字幕在线观看 | 久久影院午夜论 | 香蕉视频4aa| 四虎永久网站 | 国产在线精品一区 | www·22com天天操 | 碰超在线观看 | 日韩免费视频一区二区 | 日韩高清片 | 成人少妇影院yyyy | 人人添人人澡 | 国产视频一区二区在线观看 | 黄色一级在线视频 | 精品久久一区二区三区 | 99视频精品全部免费 在线 | 在线成人免费 | japanese黑人亚洲人4k | 天堂av网站 | 国产一级二级在线播放 | 日本久久久精品视频 | 精品国产免费一区二区三区五区 | 国产精品三级视频 | 久久伊人婷婷 | 在线日韩一区 | 精品久久久久久亚洲综合网站 | 91传媒激情理伦片 | 91在线中字| a级国产乱理伦片在线播放 久久久久国产精品一区 | 片网址 | 69xxxx欧美| 人人超碰97 | 亚洲综合视频在线 | 亚洲精品视频网址 | 久久久久女教师免费一区 | 精品夜夜嗨av一区二区三区 | 国产精品久久久久久妇 | 久久视频在线观看免费 | 中文字幕日本在线 | 91在线porny国产在线看 | 免费观看xxxx9999片 | 日日夜夜天天久久 | 色播激情五月 | 91大神电影 | 久久精品欧美日韩精品 | www.狠狠插.com | 色视频网站在线观看一=区 a视频免费在线观看 | 人人爽人人爽人人爽 | 亚洲国产午夜视频 | 91av99| 色综合天天爱 | 日韩在线看片 | 久久99久国产精品黄毛片入口 | 国产婷婷 | av在线免费观看网站 | 久久视频 | 一区二区三区四区五区在线视频 | 国产99久久久国产精品免费二区 | 六月婷色 | 国产麻豆剧果冻传媒视频播放量 | 久久久污 | 一本一道久久a久久综合蜜桃 | 亚洲精品成人av在线 | 免费亚洲成人 | 麻豆91在线观看 | 91亚洲狠狠婷婷综合久久久 | 人人澡人人草 | 国产一级黄色片免费看 | 午夜久久久精品 | 成人在线网站观看 | 国产视频久久 | 啪啪激情网 | 在线观看精品国产 | 激情av资源| 久久免费片 | 久久99国产精品视频 | 亚洲va欧美va人人爽春色影视 | 国产69久久 | 男女全黄一级一级高潮免费看 | 久久久久在线视频 | 激情av网址| 欧美日韩aa | 99热都是精品 | 欧美国产日韩一区二区三区 | 免费视频色 | 天天射天天射天天 | 91精品国自产在线观看 | 国产色a在线观看 | 亚洲最大成人免费网站 | 色婷婷福利 | 蜜臀av性久久久久蜜臀aⅴ四虎 | 毛片永久新网址首页 | 久久久久久久久久久免费av | 干干夜夜 | 天堂在线成人 | 天天干天天拍 | 久久久久9999亚洲精品 | 国产在线高清 | 免费精品国产va自在自线 | 色综合久久久久综合体 | 精品中文字幕在线播放 | av电影在线不卡 | 91成人精品在线 | 久久久久成人精品亚洲国产 | 色天天综合久久久久综合片 | 久久精品中文字幕少妇 | 婷婷日日| 黄色免费网战 | 青青久草在线 | 中文在线免费视频 | 亚洲电影影音先锋 | 免费高清在线观看成人 | 国产精品五月天 | 国产高清不卡 | 国产精品 中文在线 | 国产剧情一区 | 亚洲天堂va | 亚洲精品乱码久久久一二三 | av一级久久 | 国产美腿白丝袜足在线av | 国产精品久久久久国产a级 激情综合中文娱乐网 | 国产精品成人自产拍在线观看 | 日韩四虎 | 精品成人国产 | 四虎免费在线观看视频 | 亚洲欧美日韩国产 | 九九在线国产视频 | 在线精品亚洲一区二区 | 天天视频色版 | 国产精品一区久久久久 | 国产涩涩网站 | 日韩三级.com| 黄网站app在线观看免费视频 | 一区二区免费不卡在线 | 国产精品视频专区 | 国产成人一级电影 | av三级在线看| 国产日产欧美在线观看 | 久香蕉 | 久久久久 免费视频 | 天天操天天干天天插 | 夜夜操天天摸 | 国内精品小视频 | 亚洲欧美视频一区二区三区 | 亚洲视频分类 | 在线观看网站黄 | 999在线视频 | 日韩欧美xxxx | 日韩免费小视频 | 国产在线观看中文字幕 | 亚洲精品小视频 | 91精品国产一区二区在线观看 | 好看av在线 | 亚洲aⅴ久久精品 | 免费久久99精品国产婷婷六月 | 伊人国产在线观看 | 狠狠色综合网站久久久久久久 | 久草热视频 | 国产精品video爽爽爽爽 | 亚洲视频www| 欧美视频www| 五月天天av | 婷婷激情综合网 | 91精品国产欧美一区二区 | 九九视频这里只有精品 | 国产精品成人一区二区三区吃奶 | 国产精品 中文字幕 亚洲 欧美 | 精品国产乱码久久久久 | 特级毛片在线 | 亚洲精品网址在线观看 | 一区 在线观看 | 91黄视频在线观看 | 中文字幕在线观看你懂的 | 久草在线免费新视频 | 欧美精品黑人性xxxx | 韩国一区二区三区在线观看 | 精品国产一区二区三区日日嗨 | 夜夜躁狠狠躁日日躁视频黑人 | 九九九九九九精品 | 久久国产精品99久久久久 | av专区在线 | www.亚洲视频.com | 国内精品久久久久国产 | av在线一 | 亚洲精品中文字幕在线 | 黄色免费观看网址 | 一区二区精品在线视频 | 少妇精品久久久一区二区免费 | 免费观看性生活大片3 | 精品久久久影院 | 亚洲va综合va国产va中文 | 99中文字幕在线观看 | 97视频人人澡人人爽 | 波多野结衣在线观看一区二区三区 | 四虎永久网站 | 精品在线二区 | www.在线观看视频 | 久久精品99久久久久久 | 五月天堂色 | 日日操天天爽 | 欧美日韩一二三四区 | 日韩中文在线视频 | 夜夜视频欧洲 | av天天色 | 国产精品亚州 | 人人澡人人爽欧一区 | 日b视频在线观看网址 | 欧美一区视频 | 在线97| 成人在线视 | 午夜精品一区二区三区可下载 | 久久人人爽人人 |