欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue頁(yè)面更新patch的實(shí)現(xiàn)示例

 更新時(shí)間:2020年03月25日 10:11:40   作者:阿正  
這篇文章主要介紹了vue頁(yè)面更新patch的實(shí)現(xiàn)示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

patch的流程

組件頁(yè)面渲染時(shí),將render返回的新vnode(新節(jié)點(diǎn))和組件實(shí)例保存的vnode(舊節(jié)點(diǎn))作為參數(shù),調(diào)用patch方法,更新DOM。

判斷兩個(gè)節(jié)點(diǎn)是否相同

處理過(guò)程中,需要判斷節(jié)點(diǎn)是否相同。相同節(jié)點(diǎn)需要滿(mǎn)足以下條件:

  • key相同
  • 標(biāo)簽類(lèi)型相同
  • 注釋節(jié)點(diǎn)標(biāo)識(shí)相同,都是注釋節(jié)點(diǎn),或者都不是注釋節(jié)點(diǎn)
  • data的值狀態(tài)相同,或者都有值,或者都沒(méi)值
function sameVnode (a, b) {// 判斷兩個(gè)VNode節(jié)點(diǎn)是否是同一個(gè)節(jié)點(diǎn)
  return (
    a.key === b.key && // key相同
    (
      a.tag === b.tag && // tag相同
      a.isComment === b.isComment && // 注釋節(jié)點(diǎn)標(biāo)識(shí)相同
      isDef(a.data) === isDef(b.data) && // data值狀態(tài)相同
      sameInputType(a, b) // input的type相同
    )
  )
}

patch方法

patch判斷流程如下:

a) 如果新節(jié)點(diǎn)為空,此時(shí)舊節(jié)點(diǎn)存在(組件銷(xiāo)毀時(shí)),調(diào)用舊節(jié)點(diǎn)destroy生命周期函數(shù)

b) 如果舊節(jié)點(diǎn)為空,根據(jù)新節(jié)點(diǎn)創(chuàng)建DOM

c) 其他(如果新舊節(jié)點(diǎn)都存在)

  • a) 舊節(jié)點(diǎn)不是DOM(組件節(jié)點(diǎn)),且新舊節(jié)點(diǎn)相同
    • 執(zhí)行patchVnode
  • b) 舊節(jié)點(diǎn)是DOM元素或者兩個(gè)節(jié)點(diǎn)不相同
    • 創(chuàng)建新節(jié)點(diǎn)DOM,銷(xiāo)毀舊節(jié)點(diǎn)以及DOM。
function patch (oldVnode, vnode, hydrating, removeOnly) {
  if (isUndef(vnode)) {
   if (isDef(oldVnode)) { invokeDestroyHook(oldVnode); }
   return
  }
  ...
  if (isUndef(oldVnode)) {
   isInitialPatch = true;// 組件初始加載
   createElm(vnode, insertedVnodeQueue);
  } else {
   var isRealElement = isDef(oldVnode.nodeType);
   if (!isRealElement && sameVnode(oldVnode, vnode)) {
    patchVnode(oldVnode, vnode, insertedVnodeQueue, null, null, removeOnly);
   } else {
    ...
    var oldElm = oldVnode.elm;
    var parentElm = nodeOps.parentNode(oldElm);// 獲取父元素
    // create new node
    createElm(
     vnode,
     insertedVnodeQueue,
     oldElm._leaveCb ? null : parentElm,
     nodeOps.nextSibling(oldElm)// 獲取緊跟的弟弟元素
    );
    if (isDef(parentElm)) {
     removeVnodes(parentElm, [oldVnode], 0, 0);// 銷(xiāo)毀舊節(jié)點(diǎn)以及DOM元素
    } else if (isDef(oldVnode.tag)) {
     invokeDestroyHook(oldVnode);
    }
   }
  }
  invokeInsertHook(vnode, insertedVnodeQueue, isInitialPatch);
  return vnode.elm
 }
}

patchVnode方法

當(dāng)兩個(gè)節(jié)點(diǎn)相同時(shí),執(zhí)行patchVnode方法。在處理各種情況之前,會(huì)將舊節(jié)點(diǎn)elm屬性值賦值給新節(jié)點(diǎn)的elm屬性,保持elm保持一致。

具體流程如下:

a)如果新舊節(jié)點(diǎn)完全相同(引用相同 oldVnode === vnode)

  • 直接返回不處理

b) 如果新節(jié)點(diǎn)不是文本節(jié)點(diǎn)

  • a)都存在子節(jié)點(diǎn),新舊節(jié)點(diǎn)的子節(jié)點(diǎn)數(shù)組引用不同(oldCh !== ch)
    • updateChildren
  • b)新節(jié)點(diǎn)有子節(jié)點(diǎn),舊節(jié)點(diǎn)沒(méi)有
    • 1)查重子節(jié)點(diǎn)(key)
    • 2)如果舊節(jié)點(diǎn)是文本節(jié)點(diǎn),先清空文本
    • 3)創(chuàng)建子節(jié)點(diǎn)DOM元素
  • c)舊節(jié)點(diǎn)有子節(jié)點(diǎn),新節(jié)點(diǎn)沒(méi)有
    • 移除子節(jié)點(diǎn)以及DOM
  • d)舊節(jié)點(diǎn)是文本節(jié)點(diǎn)
    • 清除文本
  • c)如果新節(jié)點(diǎn)是文本節(jié)點(diǎn),并且和舊節(jié)點(diǎn)文本不相同
    • 則直接替換文本內(nèi)容。
  • d)其他(新節(jié)點(diǎn)是文本節(jié)點(diǎn),并且和舊節(jié)點(diǎn)相同)
    • 不處理
 function patchVnode (
  oldVnode,
  vnode,
  insertedVnodeQueue,
  ownerArray,
  index,
  removeOnly
 ) {
  if (oldVnode === vnode) {
   return
  }
  ...
  if (isUndef(vnode.text)) {
   if (isDef(oldCh) && isDef(ch)) {
    if (oldCh !== ch) { updateChildren(elm, oldCh, ch, insertedVnodeQueue, removeOnly); }
   } else if (isDef(ch)) {
    if (process.env.NODE_ENV !== 'production') {
     checkDuplicateKeys(ch);
    }
    if (isDef(oldVnode.text)) { nodeOps.setTextContent(elm, ''); }
    addVnodes(elm, null, ch, 0, ch.length - 1, insertedVnodeQueue);
   } else if (isDef(oldCh)) {
    removeVnodes(elm, oldCh, 0, oldCh.length - 1);
   } else if (isDef(oldVnode.text)) {
    nodeOps.setTextContent(elm, '');
   }
  } else if (oldVnode.text !== vnode.text) {
   nodeOps.setTextContent(elm, vnode.text);
  }
  ...
 }

updateChildren方法

updateChildren方法處理相同新舊節(jié)點(diǎn)的子節(jié)點(diǎn)。方法定義了以下變量(updateChildren的節(jié)點(diǎn)都表示的是子節(jié)點(diǎn)):

  var oldStartIdx = 0;// 表示當(dāng)前正在處理的舊起始節(jié)點(diǎn)序號(hào)
  var newStartIdx = 0;// 表示當(dāng)前正在處理的新起始節(jié)點(diǎn)序號(hào)
  var oldEndIdx = oldCh.length - 1;// 表示當(dāng)前正在處理的舊結(jié)尾節(jié)點(diǎn)序號(hào)
  var oldStartVnode = oldCh[0];// 表示當(dāng)前正在處理的舊起始節(jié)點(diǎn)
  var oldEndVnode = oldCh[oldEndIdx];// 表示當(dāng)前正在處理的舊結(jié)尾節(jié)點(diǎn)
  var newEndIdx = newCh.length - 1;// 表示當(dāng)前正在處理的新結(jié)尾節(jié)點(diǎn)序號(hào)
  var newStartVnode = newCh[0];// 表示當(dāng)前正在處理的新起始節(jié)點(diǎn)
  var newEndVnode = newCh[newEndIdx];// 表示當(dāng)前正在處理的新結(jié)尾節(jié)點(diǎn)
  var oldKeyToIdx, // 尚未處理的舊節(jié)點(diǎn)key值映射
    idxInOld, // 與新節(jié)點(diǎn)key值相同的舊節(jié)點(diǎn)序號(hào)
    vnodeToMove, // 與新節(jié)點(diǎn)key值相同的舊節(jié)點(diǎn)
    refElm;// 指向當(dāng)前正在處理的新結(jié)尾節(jié)點(diǎn)的后一個(gè)節(jié)點(diǎn)(已處理)的DOM元素

根據(jù)新舊節(jié)點(diǎn)的對(duì)比結(jié)果,更新DOM元素,此過(guò)程并不改變新舊節(jié)點(diǎn)的排序。序號(hào)指向正在處理的節(jié)點(diǎn),分別是新舊節(jié)點(diǎn)的起始和結(jié)尾節(jié)點(diǎn)。對(duì)比過(guò)程以新起始節(jié)點(diǎn)為主導(dǎo),對(duì)比方向是由兩側(cè)向中間。優(yōu)先比對(duì)新舊節(jié)點(diǎn)的起始節(jié)點(diǎn)和結(jié)尾節(jié)點(diǎn),再查找與新起始節(jié)點(diǎn)相同的且未處理的舊節(jié)點(diǎn)。當(dāng)舊節(jié)點(diǎn)全部處理完(舊起始和結(jié)尾序號(hào)重疊),此時(shí)新節(jié)點(diǎn)可能未處理完,就添加新節(jié)點(diǎn)DOM元素。當(dāng)新節(jié)點(diǎn)全部處理完(新起始和結(jié)尾序號(hào)重疊),可能存在舊節(jié)點(diǎn),就刪除舊節(jié)點(diǎn)DOM元素。

具體流程如下:

新舊子節(jié)點(diǎn)的起始序號(hào)不大于結(jié)尾序號(hào)時(shí),執(zhí)行以下流程:

a)如果舊子節(jié)點(diǎn)兩側(cè)存在undefined節(jié)點(diǎn)

  • 舊起始節(jié)點(diǎn)undefined,oldStartVnode = oldCh[++oldStartIdx]
  • 舊結(jié)尾節(jié)點(diǎn)undefined,oldEndVnode = oldCh[--oldEndIdx]

b)新舊子節(jié)點(diǎn)的起始節(jié)點(diǎn)相同(前后比較)

  • patchVNode更新DOM內(nèi)容
  • oldStartVnode = oldCh[++oldStartIdx]
  • newStartVnode = newCh[++newStartIdx]

c)新舊子節(jié)點(diǎn)的結(jié)尾節(jié)點(diǎn)相同(前后比較)

  • patchVNode更新DOM內(nèi)容
  • oldEndVnode = oldCh[--oldEndIdx]
  • newEndVnode = newCh[--newEndIdx]

d)舊起始節(jié)點(diǎn)和新結(jié)尾節(jié)點(diǎn)相同(前后比較)

  • patchVNode更新DOM內(nèi)容
  • 將舊起始節(jié)點(diǎn)DOM添加到舊結(jié)尾節(jié)點(diǎn)DOM前面
  • oldStartVnode = oldCh[++oldStartIdx]
  • newEndVnode = newCh[--newEndIdx]

e)舊結(jié)尾節(jié)點(diǎn)和新起始節(jié)點(diǎn)相同(前后比較)

  • patchVNode更新DOM內(nèi)容
  • 將舊結(jié)尾節(jié)點(diǎn)DOM添加到舊起始節(jié)點(diǎn)DOM前面
  • oldEndVnode = oldCh[--oldEndIdx]
  • newStartVnode = newCh[++newStartIdx]

f)其他(緩存尚未處理的舊節(jié)點(diǎn)key值,依此判斷舊節(jié)點(diǎn)中是否存在和新起始節(jié)點(diǎn)相同的節(jié)點(diǎn))

  • a)尚未處理的舊節(jié)點(diǎn)中不存在與新起始節(jié)點(diǎn)相同的節(jié)點(diǎn)
    • 創(chuàng)建新節(jié)點(diǎn)DOM并添加到舊起始節(jié)點(diǎn)DOM的前面
    • newStartVnode = newCh[++newStartIdx]
  • b)舊節(jié)點(diǎn)中存在與新起始節(jié)點(diǎn)key相同的節(jié)點(diǎn)
    • a)舊節(jié)點(diǎn)中存在與新起始節(jié)點(diǎn)相同的節(jié)點(diǎn)
      • patchVode
      • 將相同的舊節(jié)點(diǎn)DOM添加到舊起始節(jié)點(diǎn)DOM前面
      • 將相同的舊節(jié)點(diǎn)置為undefinedoldCh[idxInOld] = undefined
      • newStartVnode = newCh[++newStartIdx]
    • b)key相同,但標(biāo)簽類(lèi)型不同的節(jié)點(diǎn)
      • 創(chuàng)建新節(jié)點(diǎn)DOM并添加到舊起始節(jié)點(diǎn)DOM的前面
      • newStartVnode = newCh[++newStartIdx]

循環(huán)結(jié)束

a)如果舊節(jié)點(diǎn)遍歷完(oldStartIdx > oldEndIdx

  • 把剩余未處理新節(jié)點(diǎn)DOM添加到上一個(gè)新結(jié)尾節(jié)點(diǎn)DOM前面(從新起始節(jié)點(diǎn)到新結(jié)尾節(jié)點(diǎn),都未處理過(guò))

b)如果新節(jié)點(diǎn)遍歷完(newStartIdx > newEndIdx

  • 移除舊起始和結(jié)尾節(jié)點(diǎn)以及他們之間的節(jié)點(diǎn)的DOM(從舊起始節(jié)點(diǎn)到舊結(jié)尾節(jié)點(diǎn),可能存在處理過(guò)的節(jié)點(diǎn),但處理過(guò)已被置為undefined)
function updateChildren (parentElm, oldCh, newCh, insertedVnodeQueue, removeOnly) {
  var oldStartIdx = 0;// 表示當(dāng)前正在處理的舊起始節(jié)點(diǎn)序號(hào)
  var newStartIdx = 0;// 表示當(dāng)前正在處理的新起始節(jié)點(diǎn)序號(hào)
  var oldEndIdx = oldCh.length - 1;// 表示當(dāng)前正在處理的舊結(jié)尾節(jié)點(diǎn)序號(hào)
  var oldStartVnode = oldCh[0];// 表示當(dāng)前正在處理的舊起始節(jié)點(diǎn)
  var oldEndVnode = oldCh[oldEndIdx];// 表示當(dāng)前正在處理的舊結(jié)尾節(jié)點(diǎn)
  var newEndIdx = newCh.length - 1;// 表示當(dāng)前正在處理的新結(jié)尾節(jié)點(diǎn)序號(hào)
  var newStartVnode = newCh[0];// 表示當(dāng)前正在處理的新起始節(jié)點(diǎn)
  var newEndVnode = newCh[newEndIdx];// 表示當(dāng)前正在處理的新結(jié)尾節(jié)點(diǎn)
  var oldKeyToIdx, idxInOld, vnodeToMove, refElm;
  ...
  while (oldStartIdx <= oldEndIdx && newStartIdx <= newEndIdx) {
   if (isUndef(oldStartVnode)) {
    oldStartVnode = oldCh[++oldStartIdx]; // Vnode has been moved left
   } else if (isUndef(oldEndVnode)) {
    oldEndVnode = oldCh[--oldEndIdx];
   } else if (sameVnode(oldStartVnode, newStartVnode)) {
    patchVnode(oldStartVnode, newStartVnode, insertedVnodeQueue, newCh, newStartIdx);
    oldStartVnode = oldCh[++oldStartIdx];
    newStartVnode = newCh[++newStartIdx];
   } else if (sameVnode(oldEndVnode, newEndVnode)) {
    patchVnode(oldEndVnode, newEndVnode, insertedVnodeQueue, newCh, newEndIdx);
    oldEndVnode = oldCh[--oldEndIdx];
    newEndVnode = newCh[--newEndIdx];
   } else if (sameVnode(oldStartVnode, newEndVnode)) { // Vnode moved right
    patchVnode(oldStartVnode, newEndVnode, insertedVnodeQueue, newCh, newEndIdx);
    canMove && nodeOps.insertBefore(parentElm, oldStartVnode.elm, nodeOps.nextSibling(oldEndVnode.elm));
    oldStartVnode = oldCh[++oldStartIdx];
    newEndVnode = newCh[--newEndIdx];
   } else if (sameVnode(oldEndVnode, newStartVnode)) { // Vnode moved left
    patchVnode(oldEndVnode, newStartVnode, insertedVnodeQueue, newCh, newStartIdx);
    canMove && nodeOps.insertBefore(parentElm, oldEndVnode.elm, oldStartVnode.elm);
    oldEndVnode = oldCh[--oldEndIdx];
    newStartVnode = newCh[++newStartIdx];
   } else {
    if (isUndef(oldKeyToIdx)) { oldKeyToIdx = createKeyToOldIdx(oldCh, oldStartIdx, oldEndIdx); }// 緩存尚未處理的舊節(jié)點(diǎn)key值
    idxInOld = isDef(newStartVnode.key)
     ? oldKeyToIdx[newStartVnode.key]
     : findIdxInOld(newStartVnode, oldCh, oldStartIdx, oldEndIdx);
    if (isUndef(idxInOld)) { // New element
     createElm(newStartVnode, insertedVnodeQueue, parentElm, oldStartVnode.elm, false, newCh, newStartIdx);
    } else {
     vnodeToMove = oldCh[idxInOld];
     if (sameVnode(vnodeToMove, newStartVnode)) {
      patchVnode(vnodeToMove, newStartVnode, insertedVnodeQueue, newCh, newStartIdx);
      oldCh[idxInOld] = undefined;
      canMove && nodeOps.insertBefore(parentElm, vnodeToMove.elm, oldStartVnode.elm);
     } else {
      // same key but different element. treat as new element
      createElm(newStartVnode, insertedVnodeQueue, parentElm, oldStartVnode.elm, false, newCh, newStartIdx);
     }
    }
    newStartVnode = newCh[++newStartIdx];
   }
  }
  if (oldStartIdx > oldEndIdx) {
   refElm = isUndef(newCh[newEndIdx + 1]) ? null : newCh[newEndIdx + 1].elm;
   addVnodes(parentElm, refElm, newCh, newStartIdx, newEndIdx, insertedVnodeQueue);
  } else if (newStartIdx > newEndIdx) {
   removeVnodes(parentElm, oldCh, oldStartIdx, oldEndIdx);
  }
 }

updateChildren的示例:

1.左邊表示新舊節(jié)點(diǎn),節(jié)點(diǎn)下面標(biāo)識(shí)起始和結(jié)尾節(jié)點(diǎn)(即正在處理的節(jié)點(diǎn))。右邊表示當(dāng)前的DOM。

2.新節(jié)點(diǎn)的起始和結(jié)尾節(jié)點(diǎn)與舊節(jié)點(diǎn)的起始和結(jié)尾節(jié)點(diǎn)互不相同,并且在舊節(jié)點(diǎn)中未找到與新起始節(jié)點(diǎn)(新節(jié)點(diǎn)f)相同的節(jié)點(diǎn)。
所以創(chuàng)建節(jié)點(diǎn)f的DOM并添加到舊起始節(jié)點(diǎn)(舊節(jié)點(diǎn)a)DOM的前面,然后新起始節(jié)點(diǎn)序號(hào)加1,表示新節(jié)點(diǎn)f已處理,當(dāng)前正在處理新起始節(jié)點(diǎn)c。

3.新節(jié)點(diǎn)的起始和結(jié)尾節(jié)點(diǎn)與舊節(jié)點(diǎn)的起始和結(jié)尾節(jié)點(diǎn)互不相同,但在舊節(jié)點(diǎn)中找到與新起始節(jié)點(diǎn)(節(jié)點(diǎn)c)相同的節(jié)點(diǎn)。
所以將舊節(jié)點(diǎn)c的DOM添加到舊起始節(jié)點(diǎn)(舊節(jié)點(diǎn)a)DOM的前面,舊節(jié)點(diǎn)c置空,然后新起始節(jié)點(diǎn)序號(hào)加1,表示新節(jié)點(diǎn)c已處理,當(dāng)前正在處理新起始節(jié)點(diǎn)e。

4.新起始節(jié)點(diǎn)(新節(jié)點(diǎn)e)和舊結(jié)尾節(jié)點(diǎn)(舊節(jié)點(diǎn)e)相同。更新舊節(jié)點(diǎn)e的DOM內(nèi)容,并將舊節(jié)點(diǎn)e的DOM移動(dòng)到舊起始節(jié)點(diǎn)(舊節(jié)點(diǎn)a)DOM的前面,舊結(jié)尾節(jié)點(diǎn)序號(hào)減1,新起始節(jié)點(diǎn)加1,表示新舊節(jié)點(diǎn)e已處理,當(dāng)前正在處理的是新起始節(jié)點(diǎn)g和舊結(jié)尾節(jié)點(diǎn)d。

5.新結(jié)尾節(jié)點(diǎn)(新節(jié)點(diǎn)d)和舊結(jié)尾節(jié)點(diǎn)(舊節(jié)點(diǎn)d)相同。僅更新舊節(jié)點(diǎn)d的DOM內(nèi)容。新結(jié)尾節(jié)點(diǎn)序號(hào)減1,舊結(jié)尾節(jié)點(diǎn)序號(hào)減1,表示新舊節(jié)點(diǎn)d已處理,當(dāng)前正在處理的是新結(jié)尾節(jié)點(diǎn)g和舊結(jié)尾節(jié)點(diǎn)c。由于舊節(jié)點(diǎn)c為空,則舊結(jié)尾節(jié)點(diǎn)為b。

6.新節(jié)點(diǎn)的起始和結(jié)尾節(jié)點(diǎn)與舊節(jié)點(diǎn)的起始和結(jié)尾節(jié)點(diǎn)互不相同,并且在舊節(jié)點(diǎn)中未找到與新起始節(jié)點(diǎn)(新節(jié)點(diǎn)g)相同的節(jié)點(diǎn)。
所以創(chuàng)建節(jié)點(diǎn)g的DOM并添加到舊起始節(jié)點(diǎn)(舊節(jié)點(diǎn)a)DOM的前面,然后新起始節(jié)點(diǎn)序號(hào)加1,表示新節(jié)點(diǎn)g已處理,當(dāng)前正在處理新起始節(jié)點(diǎn)d。

7.由于新起始和結(jié)尾節(jié)點(diǎn)序號(hào)重疊,新節(jié)點(diǎn)已經(jīng)處理完畢,存在尚未處理的舊節(jié)點(diǎn),則移除未處理的舊節(jié)點(diǎn)DOM。

8.結(jié)束,最終的DOM。

到此這篇關(guān)于vue頁(yè)面更新patch的實(shí)現(xiàn)示例的文章就介紹到這了,更多相關(guān)vue 更新patch內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Vue多重文字描邊組件實(shí)現(xiàn)示例詳解

    Vue多重文字描邊組件實(shí)現(xiàn)示例詳解

    這篇文章主要為大家介紹了Vue多重文字描邊組件實(shí)現(xiàn)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-06-06
  • vue3?ref實(shí)現(xiàn)響應(yīng)式的方法

    vue3?ref實(shí)現(xiàn)響應(yīng)式的方法

    這篇文章主要介紹了vue3的ref是如何實(shí)現(xiàn)響應(yīng)式的,我們講了ref是如何實(shí)現(xiàn)響應(yīng)式的,主要分為兩種情況:ref接收的是number這種原始類(lèi)型、ref接收的是對(duì)象這種非原始類(lèi)型,需要的朋友可以參考下
    2024-07-07
  • Vue3如何獲取proxy對(duì)象的值而不是引用的方式

    Vue3如何獲取proxy對(duì)象的值而不是引用的方式

    這篇文章主要介紹了Vue3如何獲取proxy對(duì)象的值而不是引用的方式,本文通過(guò)示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-10-10
  • 教你三分鐘掌握Vue過(guò)濾器filters及時(shí)間戳轉(zhuǎn)換

    教你三分鐘掌握Vue過(guò)濾器filters及時(shí)間戳轉(zhuǎn)換

    這篇文章教你三分鐘掌握Vue過(guò)濾器filters及時(shí)間戳轉(zhuǎn)換,本文將結(jié)合時(shí)間戳轉(zhuǎn)換的例子帶你快速了解filters的用法,需要的朋友可以參考下
    2023-03-03
  • VUE實(shí)現(xiàn)一個(gè)Flappy Bird游戲的示例代碼

    VUE實(shí)現(xiàn)一個(gè)Flappy Bird游戲的示例代碼

    這篇文章主要介紹了VUE實(shí)現(xiàn)一個(gè)Flappy Bird的示例代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-04-04
  • vue實(shí)現(xiàn)點(diǎn)擊按鈕倒計(jì)時(shí)

    vue實(shí)現(xiàn)點(diǎn)擊按鈕倒計(jì)時(shí)

    這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)點(diǎn)擊按鈕倒計(jì)時(shí),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-07-07
  • Vue動(dòng)態(tài)樣式幾種常用方法總結(jié)

    Vue動(dòng)態(tài)樣式幾種常用方法總結(jié)

    這篇文章主要給大家介紹了關(guān)于Vue動(dòng)態(tài)樣式幾種常用方法總結(jié)的相關(guān)資料,在我們的前端界面中,很多的地方的樣式都是不確定的狀態(tài),要根據(jù)其他內(nèi)容的變化而變化樣式的,需要的朋友可以參考下
    2023-08-08
  • Vue二次封裝axios為插件使用詳解

    Vue二次封裝axios為插件使用詳解

    這篇文章主要介紹了Vue二次封裝axios為插件使用詳解,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-05-05
  • Vue動(dòng)態(tài)修改網(wǎng)頁(yè)標(biāo)題的方法及遇到問(wèn)題

    Vue動(dòng)態(tài)修改網(wǎng)頁(yè)標(biāo)題的方法及遇到問(wèn)題

    Vue下有很多的方式去修改網(wǎng)頁(yè)標(biāo)題,這里總結(jié)下解決此問(wèn)題的幾種方案:,需要的朋友可以參考下
    2019-06-06
  • 利用vue控制元素的顯示與隱藏

    利用vue控制元素的顯示與隱藏

    大家都知道在vue中我們可以使用v-if或者v-show去做隱藏顯示,下面這篇文章主要給大家介紹了關(guān)于如何利用vue控制元素的顯示與隱藏的相關(guān)資料,需要的朋友可以參考下
    2022-12-12

最新評(píng)論