кодесурса
«Вью

Пользовательские Директивы

script1adsense2code
script1adsense3code

Vue также позволяет нам регистрировать наши собственные пользовательские директивы помимо набора по умолчанию директив, которые поставляются в ядре (v-show и v-model). В Vue 2.0 основное повторное использование и абстракция кода - это компоненты, однако могут быть случаи, когда нам нужен некоторый низкоуровневый доступ к DOM для простых элементов, здесь будут по-прежнему полезны пользовательские директивы. Типичный пример - фокусировка на элементе ввода, таком как текст ввода.

При загрузке страницы элемент получает фокус (Примечание: автофокус не работает в мобильном сафари). Если после посещения страницы никто не нажимал ни на что другое, ввод текста должен быть сфокусирован. Давайте построим директиву, которая выполнит это:

JS

// Registering a global custom directive called `v-focus`
Vue.directive('focus', {
  // When the bound element is inserted into the DOM...
  inserted: function (el) {
    // Focus the element
    el.focus()
  }
})

Вместо этого, если мы хотим зарегистрировать директиву локально, компоненты также принимают опцию директив:

directives: {
  focus: {
    // directive definition
    inserted: function (el) {
      el.focus()
    }
  }
}

Теперь мы можем использовать новый атрибут v-focus для любого элемента в нашем шаблоне, как показано ниже:

<input v-focus>

Крюк Функции

Объектом определения директивы может быть предоставлено несколько хуковских функций:

  • bind: это вызывается только один раз, когда директива сначала привязана к элементу. Здесь мы можем выполнить разовую настройку.
  • вставлено: это вызывается, когда связанный элемент был вставлен в его родительский узел (это только гарантирует присутствие родительского узла, а не обязательно в документе).
  • update: вызывается после обновления VNode содержащего компонента, но, возможно, перед обновлением его дочерних элементов. Значение директивы может изменяться или не изменяться, но мы можем пропустить ненужные обновления, сравнивая текущие и старые значения привязки (см. Аргументы ловушки ниже).
  • componentUpdated: это вызывается после того, как VNode содержащего компонента и VNodes его дочерних элементов обновлены.
  • unbind: вызывается только один раз, когда директива не связана с элементом.

В следующем разделе мы рассмотрим аргументы, передаваемые в эти хуки.

Директива Аргументы Крюка

директивные аргументы не всегда статичны; они могут быть динамичными. Например, в v-mydirective: [аргумент] = "значение" аргумент может быть обновлен на основе свойств данных в нашем экземпляре компонента !. Таким образом, наши пользовательские директивы гибки во всем приложении.

Допустим, мы хотим создать собственную директиву, которая позволит нам прикреплять элементы к нашей странице с помощью фиксированного позиционирования. Мы могли бы создать пользовательскую директиву, где значение будет обновлять вертикальное положение в пикселях, как показано ниже:

HTML

<div id="baseexample">
  <p>Scroll down the page</p>
  <p v-pin="200">Stick me 200px from the top of the page</p>
</div>

JS

Vue.directive('pin', {
  bind: function (el, binding, vnode) {
    el.style.position ='fixed'
    el.style.top = binding.value + 'px'
  }
})
new Vue({
  el: '#baseexample'
})

Этот фрагмент будет закреплять элемент на 200 пикселей сверху страницы. Как насчет того, когда нам нужно прикрепить элемент слева, а не сверху? Использование динамического аргумента, который может быть обновлен для каждого экземпляра компонента, очень удобно:

HTML

<div id="dynamicexample">
  <h3>Scroll down inside this section ?</h3>
  <p v-pin:[direction]="200">I am pinned onto the page at 200px to the left.</p>
</div>

JS

Vue.directive('pin', {
  bind: function (el, binding, vnode) {
    el.style.position ='fixed'
    var s = (binding.arg =='left' ? 'left' : 'top')
    el.style[s] = binding.value + 'px'
  }
})
new Vue({
  el: '#dynamicexample',
  data: function () {
    return {
      direction: 'left'
    }
  }
})

Благодаря этому наша пользовательская директива достаточно гибкая, чтобы поддерживать различные варианты использования.

Функция Сокращения

Есть очень много случаев, когда мы можем хотеть того же поведения при связывании и обновлении, и не заботиться о других хуках. Например:

Vue.directive('color-swatch', function (el, binding) {
  el.style.backgroundColor = binding.value
})

Объектные литералы

Если нашей директиве нужно несколько значений, мы также можем передать литерал объекта JavaScript.

HTML

<div v-demo="{ color: 'white', text: 'hello!' }"></div>

JS

Vue.directive('demo', function (el, binding) {
  console.log(binding.value.color) // => "white"
  console.log(binding.value.text)  // => "hello!"
})

Новый контент: Composer: менеджер зависимостей для PHP , R программирования


script1adsense4code
script1adsense5code
disqus2code
script1adsense6code
script1adsense7code
script1adsense8code
buysellads2code