Heim Web-Frontend View.js Teilen Sie einige häufig verwendete benutzerdefinierte Anweisungen in Vuejs (Zusammenfassung)

Teilen Sie einige häufig verwendete benutzerdefinierte Anweisungen in Vuejs (Zusammenfassung)

Jul 08, 2021 am 10:56 AM
vue.js 自定义指令

Passen Sie in Vuejs einige Anweisungen an, um das zugrunde liegende DOM zu bearbeiten. Der folgende Artikel fasst einige häufig verwendete benutzerdefinierte Befehlscodes zusammen und teilt sie, die direkt zur Verbesserung der Entwicklungseffizienz verwendet werden können!

Teilen Sie einige häufig verwendete benutzerdefinierte Anweisungen in Vuejs (Zusammenfassung)

【Verwandte Empfehlung: „vue.js-Tutorial“】

1. Anleitung zur Element-Klickbereichserweiterung v-expandClick

Verwenden Sie diese Anweisung, um den Klickbereich des Elements implizit zu erweitern Ausleihen einer Pseudo-Element-Implementierung, sodass die Anordnung und das Layout der Elemente auf der Seite nicht beeinträchtigt werden.

Die Parameter, die übergeben werden können, sind: der Bereich der oberen, rechten, unteren und linken Erweiterung in Pixel, und die Standarderweiterung beträgt 10 Pixel. Der Code der Anweisung lautet wie folgt:

export default function (el, binding) {
    const s = document.styleSheets[document.styleSheets.length - 1]
    const DEFAULT = -10 // 默认向外扩展10px
    const ruleStr = `content:"";position:absolute;top:-${top || DEFAULT}px;bottom:-${bottom || DEFAULT}px;right:-${right || DEFAULT}px;left:-${left || DEFAULT}px;`
    const [top, right, bottom, left] = binding.expression && binding.expression.split(',') || []
    const classNameList = el.className.split(' ')
    el.className = classNameList.includes('expand_click_range') ? classNameList.join(' ') : [...classNameList, 'expand_click_range'].join(' ')
    el.style.position = el.style.position || "relative"
    if (s.insertRule) {
        s.insertRule('.expand_click_range::before' + '{' + ruleStr + '}', s.cssRules.length)
    } else { /* IE */
        s.addRule('.expand_click_range::before', ruleStr, -1)
    }
}
Nach dem Login kopieren

Parameterattribute:

Teilen Sie einige häufig verwendete benutzerdefinierte Anweisungen in Vuejs (Zusammenfassung)

Anschließend können Sie die neue v-expandClick-Eigenschaft für jedes Element in der Vorlage wie folgt verwenden:

<div v-expandClick="20,30,40,50" @click="glabClickoutside"> 点击范围扩大</div>
Nach dem Login kopieren

2 v-copy

Verwenden Sie diesen Befehl, um den Textinhalt des Elements zu kopieren (der Befehl unterstützt drei Modi: Klicken Sie, um v-copy zu kopieren, doppelklicken Sie, um v-copy.dblclick zu kopieren, und klicken Sie auf das Symbol, um v zu kopieren -copy.icon). Wenn keine Parameter übergeben werden, wird standardmäßig „Klicken“ verwendet. Der Code der

-Direktive lautet wie folgt:

export default {
  bind (el, binding) {
    // 双击触发复制
    if (binding.modifiers.dblclick) {
      el.addEventListener(&#39;dblclick&#39;, () => handleClick(el.innerText))
      el.style.cursor = &#39;copy&#39;
    }
    // 点击icon触发复制
    else if (binding.modifiers.icon) {
      if (el.hasIcon) return
      const iconElement = document.createElement(&#39;i&#39;)
      iconElement.setAttribute(&#39;class&#39;, &#39;el-icon-document-copy&#39;)
      iconElement.setAttribute(&#39;style&#39;, &#39;margin-left:5px&#39;)
      el.appendChild(iconElement)
      el.hasIcon = true
      iconElement.addEventListener(&#39;click&#39;, () => handleClick(el.innerText))
      iconElement.style.cursor = &#39;copy&#39;
    }
    // 单击触发复制
    else {
      el.addEventListener(&#39;click&#39;, () => handleClick(el.innerText))
      el.style.cursor = &#39;copy&#39;
    }
  }
}

function handleClick (text) {
  // 创建元素
  if (!document.getElementById(&#39;copyTarget&#39;)) {
    const copyTarget = document.createElement(&#39;input&#39;)
    copyTarget.setAttribute(&#39;style&#39;, &#39;position:fixed;top:0;left:0;opacity:0;z-index:-1000;&#39;)
    copyTarget.setAttribute(&#39;id&#39;, &#39;copyTarget&#39;)
    document.body.appendChild(copyTarget)
  }

  // 复制内容
  const input = document.getElementById(&#39;copyTarget&#39;)
  input.value = text
  input.select()
  document.execCommand(&#39;copy&#39;)
  // alert(&#39;复制成功&#39;)
}
Nach dem Login kopieren

Parameterattribute:

Teilen Sie einige häufig verwendete benutzerdefinierte Anweisungen in Vuejs (Zusammenfassung)

Anschließend können Sie die neue V-Copy-Eigenschaft für jedes Element in der Vorlage wie folgt verwenden:

<div v-copy> 单击复制 </div>
<div v-copy.dblclick> 双击复制 </div>
<div v-copy.icon> icon复制 </div>
Nach dem Login kopieren

3. Element Vollbildbefehl v-screenfull
Vollbildbefehl, klicken Sie auf das Element, um den Vollbildmodus auszuführen/den Vollbildvorgang zu beenden. Unterstützt, ob das Vollbildsymbol el-icon-full-screen von element-ui nach dem Element eingefügt werden soll. Der Code der

-Direktive lautet wie folgt:

import screenfull from &#39;screenfull&#39;

export default {
  bind (el, binding) {
    if (binding.modifiers.icon) {
      if (el.hasIcon) return
      // 创建全屏图标
      const iconElement = document.createElement(&#39;i&#39;)
      iconElement.setAttribute(&#39;class&#39;, &#39;el-icon-full-screen&#39;)
      iconElement.setAttribute(&#39;style&#39;, &#39;margin-left:5px&#39;)
      el.appendChild(iconElement)
      el.hasIcon = true
  }
    el.style.cursor = el.style.cursor || &#39;pointer&#39;
    // 监听点击全屏事件
    el.addEventListener(&#39;click&#39;, () => handleClick())
  }
}

function handleClick () {
  if (!screenfull.isEnabled) {
    alert(&#39;浏览器不支持全屏&#39;)
    return
  }
  screenfull.toggle()
}
Nach dem Login kopieren

Parameterattribute:

Teilen Sie einige häufig verwendete benutzerdefinierte Anweisungen in Vuejs (Zusammenfassung)

Dann können Sie die neue v-screenfull-Eigenschaft wie folgt für jedes Element in der Vorlage verwenden:

<div v-screenfull.icon> 全屏 </div>
Nach dem Login kopieren

4 Beschreibungsanweisung V-Tooltip

Fügen Sie dem Element eine Beschreibung hinzu, genau wie der El-Tooltip von Element-UI (das Fragezeichensymbol zeigt den Beschreibungstext an, nachdem es mit der Maus abgedeckt wurde). Der Code der

Teilen Sie einige häufig verwendete benutzerdefinierte Anweisungen in Vuejs (Zusammenfassung)

-Direktive lautet wie folgt:

import Vue from &#39;vue&#39;
export default function (el, binding) {
    if (el.hasIcon) return
    const iconElement = structureIcon(binding.arg, binding.value)
    el.appendChild(iconElement)
    el.hasIcon = true
}

function structureIcon (content, attrs) {
    // 拼接绑定属性
    let attrStr = &#39;&#39;
    for (let key in attrs) {
        attrStr += `${key}=${attrs[key]} `
    }
    const a = `<el-tooltip content=${content} ${attrStr}><i class="el-icon-question" style="margin:0 10px"></i></el-tooltip>`
    // 创建构造器
    const tooltip = Vue.extend({
        template: a
    })
    // 创建一个 tooltip 实例并返回 dom 节点
    const component = new tooltip().$mount()
    return component.$el
}
Nach dem Login kopieren

Parameterattribute:

Teilen Sie einige häufig verwendete benutzerdefinierte Anweisungen in Vuejs (Zusammenfassung)

Anschließend können Sie die neue V-Tooltip-Eigenschaft für jedes Element in der Vorlage wie folgt verwenden:

<div v-tooltip:content=&#39;tootipParams&#39;> 提示 </div>
Nach dem Login kopieren

Zum Beispiel :

<div v-tooltip:提示内容为XXX1> 提示1</div>
<div v-tooltip:提示内容为XXX=&#39;tootipParams&#39;> 提示2 </div>
Nach dem Login kopieren

ist die Anweisung. Übergeben Sie die von element-ui unterstützten Parameter:

data() {
    return {
        tootipParams: {
            placement: &#39;top&#39;,
            effect: &#39;light&#39;,
        }
    }
}
Nach dem Login kopieren

5. Text überschreitet die Ellipsenanweisung v-ellipsis

Verwenden Sie diese Anweisung, um automatisch in eine Ellipsenform zu wechseln, wenn der Textinhalt die überschreitet Breite (Standard 100 px). Entspricht der Verwendung von CSS:

width: 100px;
whiteSpace: nowrap
overflow: hidden;
textOverflow: ellipsis;
Nach dem Login kopieren

Direktiveneffekt verwenden:

Teilen Sie einige häufig verwendete benutzerdefinierte Anweisungen in Vuejs (Zusammenfassung)

Der Code der Direktive lautet wie folgt:

export default function (el, binding) {
    el.style.width = binding.arg || 100 + &#39;px&#39;
    el.style.whiteSpace = &#39;nowrap&#39;
    el.style.overflow = &#39;hidden&#39;;
    el.style.textOverflow = &#39;ellipsis&#39;;
}
Nach dem Login kopieren
Nach dem Login kopieren

Parameterattribute:

Teilen Sie einige häufig verwendete benutzerdefinierte Anweisungen in Vuejs (Zusammenfassung)

Dann können Sie die neue v-ellipsis-Eigenschaft für jedes Element verwenden in der Vorlage wie folgt:

<div v-ellipsis:100> 需要省略的文字是阿萨的副本阿萨的副本阿萨的副本阿萨的副本</div>
Nach dem Login kopieren

6. Zurück zum Anfangsbefehl v-backtop
Verwenden Sie diesen Befehl, um die Seite oder das angegebene Element wieder an den Anfang zu bringen.

Optional angegebenes Element. Wenn nicht angegeben, kehrt die globale Seite nach oben zurück. Zeigen Sie optional das Backtop-Element nach einem Versatz von 400 Pixel an, z. B. zeigen Sie die Backtop-Schaltfläche nach dem Scrollen um 400 Pixel an. Der Code der

Teilen Sie einige häufig verwendete benutzerdefinierte Anweisungen in Vuejs (Zusammenfassung)

-Direktive lautet wie folgt:

export default {
  bind (el, binding, vnode) {
    // 响应点击后滚动到元素顶部
    el.addEventListener(&#39;click&#39;, () => {
    const target = binding.arg ? document.getElementById(binding.arg) : window
    target.scrollTo({
      top: 0,
      behavior: &#39;smooth&#39;
      })
    })
  },
  update (el, binding, vnode) {
    // 滚动到达参数值才出现绑定指令的元素
    const target = binding.arg ? document.getElementById(binding.arg) : window
    if (binding.value) {
      target.addEventListener(&#39;scroll&#39;, (e) => {
        if (e.srcElement.scrollTop > binding.value) {
          el.style.visibility = &#39;unset&#39;
        } else {
          el.style.visibility = &#39;hidden&#39;
        }
      })
    }
    // 判断初始化状态
    if (target.scrollTop < binding.value) {
      el.style.visibility = &#39;hidden&#39;
    }
  },
  unbind (el) {
    const target = binding.arg ? document.getElementById(binding.arg) : window
    target.removeEventListener(&#39;scroll&#39;)
    el.removeEventListener(&#39;click&#39;)
  }
}
Nach dem Login kopieren

Parameterattribute:

Teilen Sie einige häufig verwendete benutzerdefinierte Anweisungen in Vuejs (Zusammenfassung)

Anschließend können Sie die neue v-backtop-Eigenschaft für jedes Element in der Vorlage verwenden, wie unten gezeigt, das Element mit dem Die ID der App wird nach dem Scrollen mit 400 Pixeln angezeigt. Das Element der Bindungsanweisung:

<div  v-backtop:app="400"> 回到顶部 </div>
Nach dem Login kopieren

kann auch so verwendet werden, was bedeutet, dass das Element der Bindungsanweisung immer angezeigt wird und die globale Seite nach oben zurückkehrt:

<div  v-backtop> 回到顶部 </div>
Nach dem Login kopieren

7. Leerzustandsanweisung v-empty

Verwenden Sie diese Anweisung. Der standardmäßige Leerzustand kann angezeigt werden. Sie können das Standardbild (optional, standardmäßig kein Bild), den Standardtextinhalt (optional, standardmäßig keine Daten) und die Angabe eines leeren Zustands (erforderlich) übergeben. Der Code der

Teilen Sie einige häufig verwendete benutzerdefinierte Anweisungen in Vuejs (Zusammenfassung)

-Direktive lautet wie folgt:

import Vue from "vue";
export default {
  update (el, binding, vnode) {
    el.style.position = el.style.position || &#39;relative&#39;
    const { offsetHeight, offsetWidth } = el
    const { visible, content, img } = binding.value
    const image = img ? `<img  src="/static/imghw/default1.png"  data-src="${img}"  class="lazy"      style="max-width:90%"  style="max-width:90%" alt="Teilen Sie einige häufig verwendete benutzerdefinierte Anweisungen in Vuejs (Zusammenfassung)" ></img>` : &#39;&#39;
    const defaultStyle = "position:absolute;top:0;left:0;z-index:9999;background:#fff;display:flex;justify-content: center;align-items: center;"
    const empty = Vue.extend({
    template: `<div style="height:${offsetHeight}px;width:${offsetWidth}px;${defaultStyle}">
      <div style="text-align:center">
        <div>${image}</div>
        <div>${content || &#39;暂无数据&#39;}</div>
      </div>
    </div>`
    })
    const component = new empty().$mount().$el
    if (visible) {
      el.appendChild(component)
    } else {
      el.removeChild(el.lastChild)
    }
  },
}
Nach dem Login kopieren

Parameterattribute:

1Teilen Sie einige häufig verwendete benutzerdefinierte Anweisungen in Vuejs (Zusammenfassung)

Anschließend können Sie die neue v-empty-Eigenschaft für jedes Element in der Vorlage verwenden und dabei das Objekt emptyValue wie folgt übergeben :

<div   style="max-width:90%" v-empty="emptyValue"> 原本内容
Nach dem Login kopieren

需要传入一个参数对象,例如显示文字为:暂无列表,图片路径为 ../../assets/images/blue_big.png,控制标示 visible:

emptyValue = {
  content: &#39;暂无列表&#39;,
  img: require(&#39;../../assets/images/blue_big.png&#39;),
  visible: true,
},
Nach dem Login kopieren

8、徽标指令 v-badge

使用该指令在元素右上角显示徽标。

支持配置徽标的背景颜色、徽标形状;支持传入徽标上显示的数字。

1Teilen Sie einige häufig verwendete benutzerdefinierte Anweisungen in Vuejs (Zusammenfassung)

指令的代码如下:

import Vue from &#39;vue&#39;

const SUCCESS = &#39;#72c140&#39;
const ERROR = &#39;#ed5b56&#39;
const WARNING = &#39;#f0af41&#39;
const INFO = &#39;#4091f7&#39;
const HEIGHT = 20
let flag = false
export default {
  update (el, binding, vnode) {
    const { modifiers, value } = binding
    const modifiersKey = Object.keys(modifiers)
    let isDot = modifiersKey.includes(&#39;dot&#39;)
    let backgroundColor = &#39;&#39;
    if (modifiersKey.includes(&#39;success&#39;)) {
      backgroundColor = SUCCESS
    } else if (modifiersKey.includes(&#39;warning&#39;)) {
      backgroundColor = WARNING
    } else if (modifiersKey.includes(&#39;info&#39;)) {
      backgroundColor = INFO
    } else {
      backgroundColor = ERROR
    }

    const targetTemplate = isDot 
        ? `<div style="position:absolute;top:-5px;right:-5px;height:10px;width:10px;border-radius:50%;background:${backgroundColor}"></div>` 
        : `<div style="background:${backgroundColor};position:absolute;top:-${HEIGHT / 2}px;right:-${HEIGHT / 2}px;height:${HEIGHT}px;min-width:${HEIGHT}px;border-radius:${HEIGHT / 2}px;text-align:center;line-height:${HEIGHT}px;color:#fff;padding:0 5px;">${value}</div>`
        
    el.style.position = el.style.position || &#39;relative&#39;
    const badge = Vue.extend({
      template: targetTemplate
    })
    const component = new badge().$mount().$el
    if (flag) {
      el.removeChild(el.lastChild)
    }
    el.appendChild(component)
    flag = true
  }
}
Nach dem Login kopieren

参数 Attributes:

1Teilen Sie einige häufig verwendete benutzerdefinierte Anweisungen in Vuejs (Zusammenfassung)

然后你可以在模板中任何元素上使用新的 v-badge property,如下:

<div v-badge.dot.info="badgeCount"   style="max-width:90%"> </div>
Nach dem Login kopieren

9、拖拽指令 v-drag

使用该指令可以对元素进行拖拽。

指令的代码如下:

export default {
  let _el = el
  document.onselectstart = function() {
    return false  //禁止选择网页上的文字
  }
  
  _el.onmousedown = e => {
    let disX = e.clientX - _el.offsetLeft //鼠标按下,计算当前元素距离可视区的距离
    let disY = e.clientY - _el.offsetTop
    document.onmousemove = function(e){     
      let l = e.clientX - disX
      let t = e.clientY - disY;
      _el.style.left = l + "px"
      _el.style.top = t + "px"
    }
    document.onmouseup = e => {
      document.onmousemove = document.onmouseup = null
    }
    return false
  }
}
Nach dem Login kopieren

然后你可以在模板中任何元素上使用新的 v-drag property,如下:

<div v-drag> 支持拖拽的元素 </div>
Nach dem Login kopieren

10、响应缩放指令 v-resize

使用该指令可以响应元素宽高改变时执行的方法。

指令的代码如下:

export default {
  bind(el, binding) {
    let width = &#39;&#39;, height = &#39;&#39;;
    function isReize() {
      const style = document.defaultView.getComputedStyle(el);
      if (width !== style.width || height !== style.height) {
        binding.value();  // 执行传入的方法
      }
      width = style.width;
      height = style.height;
     }
     el.__timer__ = setInterval(isReize, 300); // 周期性监听元素是否改变
  },
  unbind(el) {
    clearInterval(el.__timer__);
  }
}
Nach dem Login kopieren

参数 Attributes:

1Teilen Sie einige häufig verwendete benutzerdefinierte Anweisungen in Vuejs (Zusammenfassung)

然后你可以在模板中任何元素上使用新的 v-resize property,如下:

// 传入 resize() 方法
<div v-resize="resize"></div>
Nach dem Login kopieren

11、字符串整形指令 v-format

使用该指令可以修改字符串,如使用 v-format.toFixed 保留两位小数、 v-format.price 将内容变成金额(每三位逗号分隔),可以同时使用,如 v-format.toFixed.price。

例如将数字 243112.331 变成 243112.33,或 243,112.33。

指令的代码如下:

export default {
  update (el, binding, vnode) {
    const { value, modifiers } = binding
    if (!value) return
    let formatValue = value
    if (modifiers.toFixed) {
      formatValue = value.toFixed(2)
    }
    console.log(formatValue)
    if (modifiers.price) {
      formatValue = formatNumber(formatValue)
    }
    el.innerText = formatValue
  },
}



function formatNumber (num) {
  num += &#39;&#39;;
  let strs = num.split(&#39;.&#39;);
  let x1 = strs[0];
  let x2 = strs.length > 1 ? &#39;.&#39; + strs[1] : &#39;&#39;;
  var rgx = /(\d+)(\d{3})/;
  while (rgx.test(x1)) {
    x1 = x1.replace(rgx, &#39;$1&#39; + &#39;,&#39; + &#39;$2&#39;);
  }
  return x1 + x2
}
Nach dem Login kopieren

参数 Attributes:

1Teilen Sie einige häufig verwendete benutzerdefinierte Anweisungen in Vuejs (Zusammenfassung)

然后你可以在模板中任何元素上使用新的 v-format property,如下:

<div v-format.toFixed.price="123333"> 123 </div>
Nach dem Login kopieren

如何使用这些指令?

为了便于管理指令,我们将每个指令都存在于单独的 js 文件中。在项目的 src 下建一个 directives 目录,目录下新建 index.js 文件用于引入并注册指令。

├── src
|  ├── directive
|  |  ├── index.js
|  |  ├── backtop.js
|  |  ├── badge.js
|  |  ├── copy.js
|  |  ├── ellipsis.js
|  |  ├── empty.js
|  |  ├── expandClick.js
|  |  ├── screenfull.js
|  |  └── tooltips.js
|  ├── main.js
Nach dem Login kopieren

举个例子:

directives 目录下新建 ellipsis.js 文件:

export default function (el, binding) {
    el.style.width = binding.arg || 100 + &#39;px&#39;
    el.style.whiteSpace = &#39;nowrap&#39;
    el.style.overflow = &#39;hidden&#39;;
    el.style.textOverflow = &#39;ellipsis&#39;;
}
Nach dem Login kopieren
Nach dem Login kopieren

directives 的 index.js 文件中引入 ellipsis 指令并注册:

import Vue from &#39;vue&#39;
import ellipsis from &#39;./ellipsis&#39; // 引入指令
// import other directives

const directives = {
  ellipsis
  // other directives
}

Object.keys(directives).forEach(name => Vue.directive(name, directives[name]))
Nach dem Login kopieren

最后在 mian.js 中引入 index.js 文件:

import &#39;@/directives/index&#39;
Nach dem Login kopieren
Nach dem Login kopieren

这样就可以正常使用这些指令了:

import &#39;@/directives/index&#39;
Nach dem Login kopieren
Nach dem Login kopieren

更多编程相关知识,请访问:编程入门!!

Das obige ist der detaillierte Inhalt vonTeilen Sie einige häufig verwendete benutzerdefinierte Anweisungen in Vuejs (Zusammenfassung). Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Chat -Befehle und wie man sie benutzt
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Ausführliche Diskussion darüber, wie Vite .env-Dateien analysiert Ausführliche Diskussion darüber, wie Vite .env-Dateien analysiert Jan 24, 2023 am 05:30 AM

Wenn wir das Vue-Framework zum Entwickeln von Front-End-Projekten verwenden, stellen wir bei der Bereitstellung mehrere Umgebungen bereit. Oft sind die von Entwicklungs-, Test- und Online-Umgebungen aufgerufenen Schnittstellendomänen unterschiedlich. Wie können wir die Unterscheidung treffen? Dabei werden Umgebungsvariablen und Muster verwendet.

Detaillierte grafische Erklärung zur Integration des Ace-Code-Editors in ein Vue-Projekt Detaillierte grafische Erklärung zur Integration des Ace-Code-Editors in ein Vue-Projekt Apr 24, 2023 am 10:52 AM

Ace ist ein in JavaScript geschriebener einbettbarer Code-Editor. Es entspricht der Funktionalität und Leistung nativer Editoren wie Sublime, Vim und TextMate. Es kann problemlos in jede Webseite und JavaScript-Anwendung eingebettet werden. Ace wird als Haupteditor für die Cloud9-IDE gepflegt und ist der Nachfolger des Mozilla Skywriter (Bespin)-Projekts.

Was ist der Unterschied zwischen Komponentisierung und Modularisierung in Vue? Was ist der Unterschied zwischen Komponentisierung und Modularisierung in Vue? Dec 15, 2022 pm 12:54 PM

Der Unterschied zwischen Komponentisierung und Modularisierung: Die Modularisierung ist aus Sicht der Codelogik unterteilt. Sie erleichtert die Entwicklung auf Codeebene und stellt sicher, dass die Funktionen jedes Funktionsmoduls konsistent sind. Die Komponentisierung ist die Planung aus der Perspektive der UI-Schnittstelle; die Komponentisierung des Frontends erleichtert die Wiederverwendung von UI-Komponenten.

Lassen Sie uns ausführlich über reactive() in vue3 sprechen Lassen Sie uns ausführlich über reactive() in vue3 sprechen Jan 06, 2023 pm 09:21 PM

Vorwort: Bei der Entwicklung von vue3 bietet reactive eine Methode zur Implementierung reaktionsfähiger Daten. Dies ist eine häufig verwendete API in der täglichen Entwicklung. In diesem Artikel wird der Autor seinen internen Betriebsmechanismus untersuchen.

Erfahren Sie, wie Sie Unit-Tests in Vue3 schreiben Erfahren Sie, wie Sie Unit-Tests in Vue3 schreiben Apr 25, 2023 pm 07:41 PM

Vue.js ist heute ein sehr beliebtes Framework in der Front-End-Entwicklung. Da sich Vue.js ständig weiterentwickelt, werden Unit-Tests immer wichtiger. Heute untersuchen wir, wie man Unit-Tests in Vue.js 3 schreibt, und stellen einige Best Practices sowie häufige Probleme und Lösungen vor.

Ein einfacher Vergleich der JSX-Syntax und der Template-Syntax in Vue (Analyse der Vor- und Nachteile) Ein einfacher Vergleich der JSX-Syntax und der Template-Syntax in Vue (Analyse der Vor- und Nachteile) Mar 23, 2023 pm 07:53 PM

In Vue.js können Entwickler zwei verschiedene Syntaxen zum Erstellen von Benutzeroberflächen verwenden: JSX-Syntax und Vorlagensyntax. Beide Syntaxen haben ihre eigenen Vor- und Nachteile. Lassen Sie uns ihre Unterschiede, Vor- und Nachteile besprechen.

Eine kurze Analyse, wie Vue den Datei-Slicing-Upload implementiert Eine kurze Analyse, wie Vue den Datei-Slicing-Upload implementiert Mar 24, 2023 pm 07:40 PM

Im eigentlichen Entwicklungsprojektprozess ist es manchmal erforderlich, relativ große Dateien hochzuladen, und dann ist der Upload relativ langsam, sodass das Front-End möglicherweise das Hochladen von Dateiabschnitten erfordert. Dies ist beispielsweise sehr einfach Der Gigabyte-Dateistrom wird in mehrere kleine Dateiströme aufgeteilt, und dann wird die Schnittstelle aufgefordert, die jeweiligen kleinen Dateiströme zu liefern.

Analysieren Sie das Prinzip der Implementierung der Kompositions-API durch Vue2 Analysieren Sie das Prinzip der Implementierung der Kompositions-API durch Vue2 Jan 13, 2023 am 08:30 AM

Seit der Veröffentlichung von Vue3 ist die Wortkompositions-API in das Blickfeld der Vue-Schreibenden gerückt. Ich glaube, jeder hat aufgrund der Veröffentlichung von @ immer gehört, wie viel besser die Kompositions-API ist als die vorherige Options-API. vue/composition-api-Plug-in, Vue2-Studenten können ebenfalls in den Bus einsteigen. Als Nächstes werden wir hauptsächlich Responsive Ref und Reactive verwenden, um eine eingehende Analyse durchzuführen, wie dieses Plug-In dies erreicht.

See all articles