撩課-Web大前端每天5道面試題-Day20

来源:https://www.cnblogs.com/gxq666/archive/2018/12/28/10188504.html
-Advertisement-
Play Games

1.vue生命周期的作用是什麼? 2. Vue實現數據雙向綁定的原理:Object.defineProperty()? 3.vue-cli如何新增自定義指令? 4.v-if 和 v-show 區別? 5.mvvm和mvc區別? ...


1.vue生命周期的作用是什麼?

它的生命周期中有多個事件鉤子,讓我們在控制整個Vue實例的過程時更容易形成好的邏輯。

 

2. Vue實現數據雙向綁定的原理:Object.defineProperty()?

vue實現數據雙向綁定主要是:
採用數據劫持結合發佈者-訂閱者模式的方式,通過Object.defineProperty()
來劫持各個屬性的setter,getter,
在數據變動時發佈消息給訂閱者,觸發相應監聽回調。
當把一個普通 Javascript 對象傳給 Vue 實例來作為它的 data 選項時,
Vue 將遍歷它的屬性,用 Object.defineProperty 將它們轉為 getter/setter。
用戶看不到 getter/setter,但是在內部它們讓 Vue 追蹤依賴,
在屬性被訪問和修改時通知變化。

vue的數據雙向綁定 將MVVM作為數據綁定的入口,
整合Observer,Compile和Watcher三者,
通過Observer來監聽自己的model的數據變化,
通過Compile來解析編譯模板指令(vue中是用來解析 {{}}),
最終利用watcher搭起observer和Compile之間的通信橋梁,
達到數據變化 —>視圖更新;
視圖交互變化(input)—>數據model變更雙向綁定效果。


js實現簡單的雙向綁定:

<body>
    <div id="app">
    <input type="text" id="txt">
    <p id="show"></p>
</div>
</body>
<script type="text/javascript">
    var obj = {}
    Object.defineProperty(obj, 'txt', {
        get: function () {
            return obj
        },
        set: function (newValue) {
            document.getElementById('txt').value = newValue
            document.getElementById('show').innerHTML = newValue
        }
    })
    document.addEventListener('keyup', function (e) {
        obj.txt = e.target.value
    })
</script>

 

3.vue-cli如何新增自定義指令?

1.創建局部指令

var app = new Vue({
    el: '#app',
    data: {    
    },
    // 創建指令(可以多個)
    directives: {
        // 指令名稱
        dir1: {
            inserted(el) {
                // 指令中第一個參數是當前使用指令的DOM
                console.log(el);
                console.log(arguments);
                // 對DOM進行操作
                el.style.width = '200px';
                el.style.height = '200px';
                el.style.background = '#000';
            }
        }
    }
})

2.全局指令

Vue.directive('dir2', {
    inserted(el) {
        console.log(el);
    }
})
3.指令的使用

<div id="app">
    <div v-dir1></div>
    <div v-dir2></div>
</div>

 

4.v-if 和 v-show 區別?

v-if按照條件是否渲染,v-show是display的block或none;

 

5.mvvm和mvc區別?

mvc和mvvm其實區別並不大。
都是一種設計思想。
主要就是mvc中Controller演變成mvvm中的viewModel。
mvvm主要解決了mvc中大量的DOM 操作使頁面渲染性能降低,
載入速度變慢,影響用戶體驗。
和當 Model 頻繁發生變化,開發者需要主動更新到View 。

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 項目開發中經常會遇到用戶在評論或者發表文章的時候會打一些表情在裡面,如果我們在開發中不去做一些處理的話,表情會出不來的,甚至是報錯,下麵簡單介紹處理方式. 項目中評論或者文章中寫入表情符號時,php報錯,或者出來時一些????。這是為什麼呢? 下麵說一下mysql中的字元集: mysql資料庫... ...
  • 問題:ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: NO)問題描述:在linux中使用mysql -uroot -p 輸入密碼提示如上錯誤解決方法: 1、先停掉原來的服務 service ...
  • 本文由雲+社區發表 一、從常見的報錯說起 ​ 故事的開頭我們先來看一個常見的sql報錯信息: ​ 相信對於這類報錯大家一定遇到過很多次了,特別對於OMG這種已內容生產為主要工作核心的BG,在內容線的存儲中,數據大一定是個繞不開的話題。這裡的數據“大”,遠不止存儲空間占用多,其中也包括了單個(表)欄位 ...
  • 資料庫相關 查詢所有資料庫 show databases; 創建資料庫 create database 資料庫名; 創建資料庫指定字元集 create database 資料庫名 character set gbk/utf8; 查看資料庫詳情 show create database 資料庫名; 刪 ...
  • 場景:代碼運行在Linux-A上,new Date() 生成的時間比當前時間早13個小時,導致存入資料庫內的時間也早13個小時,但前臺讀取展示出來的時間又是正常的。在資料庫直接select now()測試出來的時間也是比當前時間早13個小時。 分析: 問題一:Linux-B上的MySQL資料庫內的時 ...
  • 同事玩Docker,在Docker裡面啟了一個Oracle 10g Express版本,在測試過程中遇到了ORA-00904: "WMSYS"."WM_CONCAT": invalid identifier錯誤。 SQL> select * from v$version; BANNER-------... ...
  • 問題:Xcode10 build 沒問題,跑虛擬機也沒問題,數據線連上run到真機上出現 Xcode 10 iOS12 "A valid provisioning profile for this executable was not found 解決方案: File>Project Setting ...
  • 轉載請標明出處,維權必究:https://www.cnblogs.com/tangZH/p/10181330.html 該錯誤是在載入so庫的時候出現的,就是找不到so庫。 一、檢查jinLibs目錄下是否有so庫 二、gradle的android{}裡面是否有設置: 三、相容性是否正確: 我們使用 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...