>웹 프론트엔드 >프런트엔드 Q&A >Vue에서 일반적으로 사용되는 API는 무엇입니까?

Vue에서 일반적으로 사용되는 API는 무엇입니까?

青灯夜游
青灯夜游원래의
2022-03-07 14:12:382654검색

vue의 API는 다음과 같습니다: 1. nextTick; 3. "$forceUpdate" 5. 필터 7. "$el"; . "$data"; 10. "$props" 등

Vue에서 일반적으로 사용되는 API는 무엇입니까?

이 튜토리얼의 운영 환경: Windows 7 시스템, vue 버전 2.9.6, DELL G3 컴퓨터.

nextTick


기능: 다음 Dom 업데이트 주기가 끝난 후 지연된 콜백을 추가합니다. 데이터를 수정한 후 업데이트된 Dom을 얻을 수 있습니다.
사용법:

Vue.nextTick( [callback, context] )
vm.$nextTick( [callback] )
// 用法2
// 作为一个 Promise 使用 (2.1.0 起新增)
Vue.nextTick()
  .then(function () {
    // DOM 更新了
  })

설명:

  • callback: 지연된 콜백 함수
  • context: 선택적 개체

ps: 2.1.0 이후의 새로운 기능: 콜백이 제공되지 않고 Promise를 지원하는 환경에서 , Promise가 반환됩니다. Vue에는 Promise 폴리필이 제공되지 않으므로 대상 브라우저가 기본적으로 Promise(IE: 왜 나를 보고 계시나요?)를 지원하지 않는 경우 폴리필을 직접 제공해야 합니다.

확장: nextTick의 실행 메커니즘 및 사용 시나리오와 관련하여 유사한 requestAnimationFrame() 및 process.nextTick()도 마스터해야 합니다. 전자는 브라우저 자체 모니터(다음 다시 그리기 전에 실행됨)입니다. 노드 환경에서는 다음 이벤트 폴링 시점에 실행된다.

mixin


기능: 믹스인을 등록하여 등록 후 생성된 모든 Vue 인스턴스에 영향을 줍니다. 플러그인 작성자는 믹스인을 사용하여 사용자 정의 동작을 구성 요소에 주입할 수 있습니다.
사용법:

// 为自定义的选项 'myOption' 注入一个处理器。
Vue.mixin({
  created: function () {
    var myOption = this.$options.myOption
    if (myOption) {
      console.log(myOption)
    }
  }
})

new Vue({
  myOption: 'hello!'
})
// => "hello!"

설명:

  • 객체: vm의 속성 또는 메서드

ps: 글로벌 믹스인은 개별적으로 생성된 각 Vue 인스턴스(타사 구성 요소 포함)에 영향을 미치므로 주의해서 사용하십시오. ) ). 대부분의 경우 이는 위의 예와 같이 사용자 정의 옵션에만 적용되어야 합니다. 반복되는 애플리케이션 믹스인을 피하기 위해 플러그인으로 게시하는 것이 좋습니다.

$forceUpdate


기능: Vue 인스턴스를 강제로 다시 렌더링합니다.
사용법:

vm.$forceUpdate()

설명: 모든 하위 구성 요소가 아니라 인스턴스 자체와 슬롯 콘텐츠에 삽입된 하위 구성 요소에만 영향을 미칩니다.

set, delete


기능: 반응형 데이터의 속성을 설정 및 삭제하고 동시에 보기 업데이트를 트리거합니다.
Usage:

// 用法1
Vue.set( target, key, value )
Vue.delete( target, key )
// 用法2
vm.$set( target, key, value )
vm.$delete( target, key )

Instructions:

  • target: 대상 객체
  • key: 추가할 속성 이름
  • value: 추가할 속성 값

ps: 주요 사용 시나리오, Vue를 피할 수 있습니다. 삭제되는 속성의 제한을 감지할 수 없습니다

filter


기능: 일부 일반적인 텍스트 형식 및 일부 표준 데이터 매핑에 사용됩니다.
사용법:

<!-- 在双花括号中 -->
{{ message | capitalize }}

<!-- 在 `v-bind` 中 -->
<div v-bind:id="rawId | formatId"></div>
// 注册
filters: {
  capitalize: function (value) {
    if (!value) return &#39;&#39;
    value = value.toString()
    return value.charAt(0).toUpperCase() + value.slice(1)
  }
}
// 全局注册
Vue.filter(&#39;capitalize&#39;, function (value) {
  if (!value) return &#39;&#39;
  value = value.toString()
  return value.charAt(0).toUpperCase() + value.slice(1)
})

new Vue({
  // ...
})

설명:

  • 필터 함수는 항상 표현식의 값(이전 작업 체인의 결과)을 첫 번째 매개변수로 받습니다.
  • 필터는 "파이프" 기호로 표시된 JavaScript 표현식 끝에 추가되어야 합니다.

ps: 필터는 {{ message | filterA('arg1', arg2) }}와 같은 여러 매개변수를 허용할 수 있습니다. 여기서 filterA는 세 개의 매개변수를 받는 필터 함수로 정의됩니다. 첫 번째 매개변수는 message 값, 두 번째 매개변수는 일반 문자열 'arg1', 세 번째 매개변수는 arg2 표현식의 값을 사용한다.

directive


기능: 사용자 정의 명령어를 등록하는 데 사용됩니다.
사용법:

<!-- 当页面加载时,该元素将获得焦点 --> 
<input v-focus>
// 注册一个全局自定义指令 `v-focus`
Vue.directive(&#39;focus&#39;, {
  // 当被绑定的元素插入到 DOM 中时……
  inserted: function (el) {
    // 聚焦元素
    el.focus()
  }
})
// 注册局部指令,组件中也接受一个 directives 的选项
directives: {
  focus: {
    // 指令的定义
    inserted: function (el) {
      el.focus()
    }
  }
}

설명:

  • inserted는 등록 명령어의 보간 기능 중 하나일 뿐입니다. 전체 등록 속성에는 다음도 포함될 수 있습니다.
    • bind: 명령어가 바인딩될 때 한 번만 호출됩니다. 일회성 초기화 설정을 수행할 수 있는 요소를 처음으로 호출합니다.
    • inserted: 바인딩된 요소가 상위 노드에 삽입될 때 호출됩니다(상위 노드만 존재하도록 보장되지만 반드시 문서에 삽입될 필요는 없습니다).
    • update: 구성 요소의 VNode가 업데이트될 때 호출되지만 하위 VNode가 업데이트되기 전에 발생할 수 있습니다. 지시문의 값은 변경되었을 수도 있고 변경되지 않았을 수도 있지만, 업데이트 전과 후의 값을 비교하여 불필요한 템플릿 업데이트를 무시할 수 있습니다.
    • comComponentUpdated: 명령어가 있는 구성 요소의 VNode와 해당 하위 VNode가 모두 업데이트된 후에 호출됩니다.
    • unbind: 명령이 요소에서 바인딩 해제될 때 한 번만 호출됩니다.
Vue.directive(&#39;my-directive&#39;, {
  bind: function () {},
  inserted: function () {},
  update: function () {},
  componentUpdated: function () {},
  unbind: function () {}
})

v-model 구문 설탕

v-model은 d5fd7aea971a85678ba271703566ebfd과 같은 양식 요소에 대한 데이터의 양방향 바인딩에 자주 사용됩니다. 기본 요소 외에도 사용자 정의 구성 요소에서도 사용할 수 있습니다.

v-model은 props: value와 events: input으로 분해될 수 있는 구문 설탕입니다. 즉, 구성 요소는 value라는 이름의 prop과 input이라는 사용자 정의 이벤트를 제공해야 합니다. 이 두 조건이 충족되면 사용자는 사용자 정의 구성 요소에서 v-model을 사용할 수 있습니다. 예를 들어 다음 예에서는 숫자 선택기를 구현합니다.

<template>
  <div>
    <button @click="increase(-1)">减 1</button>
    <span >{{ currentValue }}</span>
    <button @click="increase(1)">加 1</button>
  </div>
</template>
<script>
  export default {
    name: &#39;InputNumber&#39;,
    props: {
      value: {
        type: Number
      }
    },
    data () {
      return {
        currentValue: this.value
      }
    },
    watch: {
      value (val) {
        this.currentValue = val;
      }
    },
    methods: {
      increase (val) {
        this.currentValue += val;
        this.$emit(&#39;input&#39;, this.currentValue);
      }
    }
  }
</script>

props 一般不能在组件内修改,它是通过父级修改的,因此实现 v-model 一般都会有一个 currentValue 的内部 data,初始时从 value 获取一次值,当 value 修改时,也通过 watch 监听到及时更新;组件不会修改 value 的值,而是修改 currentValue,同时将修改的值通过自定义事件 input 派发给父组件,父组件接收到后,由父组件修改 value。所以,上面的数字选择器组件可以有下面两种使用方式:

<template>
  <InputNumber v-model="value" />
</template>
<script>
  import InputNumber from &#39;../components/input-number/input-number.vue&#39;;

  export default {
    components: { InputNumber },
    data () {
      return {
        value: 1
      }
    }
  }
</script>

或:

<template>
  <InputNumber :value="value" @input="handleChange" />
</template>
<script>
  import InputNumber from &#39;../components/input-number/input-number.vue&#39;;

  export default {
    components: { InputNumber },
    data () {
      return {
        value: 1
      }
    },
    methods: {
      handleChange (val) {
        this.value = val;
      }
    }
  }
</script>

如果你不想用 value 和 input 这两个名字,从 Vue.js 2.2.0 版本开始,提供了一个 model 的选项,可以指定它们的名字,所以数字选择器组件也可以这样写:

<template>
  <div>
    <button @click="increase(-1)">减 1</button>
    <span >{{ currentValue }}</span>
    <button @click="increase(1)">加 1</button>
  </div>
</template>
<script>
  export default {
    name: &#39;InputNumber&#39;,
    props: {
      number: {
        type: Number
      }
    },
    model: {
      prop: &#39;number&#39;,
      event: &#39;change&#39;
    },
    data () {
      return {
        currentValue: this.number
      }
    },
    watch: {
      value (val) {
        this.currentValue = val;
      }
    },
    methods: {
      increase (val) {
        this.currentValue += val;
        this.$emit(&#39;number&#39;, this.currentValue);
      }
    }
  }
</script>

在 model 选项里,就可以指定 prop 和 event 的名字了,而不一定非要用 value 和 input,因为这两个名字在一些原生表单元素里,有其它用处。

.sync 修饰符

如果你使用过 Vue.js 1.x,一定对 .sync 不陌生。在 1.x 里,可以使用 .sync 双向绑定数据,也就是父组件或子组件都能修改这个数据,是双向响应的。在 Vue.js 2.x 里废弃了这种用法,目的是尽可能将父子组件解耦,避免子组件无意中修改了父组件的状态。

不过在 Vue.js 2.3.0 版本,又增加了 .sync 修饰符,但它的用法与 1.x 的不完全相同。2.x 的 .sync 不是真正的双向绑定,而是一个语法糖,修改数据还是在父组件完成的,并非在子组件。

仍然是数字选择器的示例,这次不用 v-model,而是用 .sync,可以这样改写:

<template>
  <div>
    <button @click="increase(-1)">减 1</button>
    <span >{{ value }}</span>
    <button @click="increase(1)">加 1</button>
  </div>
</template>
<script>
  export default {
    name: &#39;InputNumber&#39;,
    props: {
      value: {
        type: Number
      }
    },
    methods: {
      increase (val) {
        this.$emit(&#39;update:value&#39;, this.value + val);
      }
    }
  }
</script>

用例:

<template>
  <InputNumber :value.sync="value" />
</template>
<script>
  import InputNumber from &#39;../components/input-number/input-number.vue&#39;;

  export default {
    components: { InputNumber },
    data () {
      return {
        value: 1
      }
    }
  }
</script>

看起来要比 v-model 的实现简单多,实现的效果是一样的。v-model 在一个组件中只能有一个,但 .sync 可以设置很多个。.sync 虽好,但也有限制,比如:

  • 不能和表达式一起使用(如 v-bind:title.sync="doc.title + '!'" 是无效的);

  • 不能用在字面量对象上(如 v-bind.sync="{ title: doc.title }" 是无法正常工作的)。

其它简单的常用属性和方法

// console.log(vm.$root); 
vm.$root    //实例对象

vm.$el  //根元素(真实的DOM元素)
// console.log(vm.$el);

vm.$el.innerHTML    //得到根元素(真实的DOM元素)中的内容
// console.log(vm.$el.innerHTML);

vm.$data    //实例下的data对象
// console.log(vm.$data);

vm.$options     //实例下的挂载项
// console.log(vm.$options);

vm.$props   //组件之间通信的数据
// console.log(vm.$props);

vm.$parent      //在组件中,指父元素
// console.log(vm.$parent);

vm.$children    //在组件中,指子代元素
// console.log(vm.$children);

vm.$attrs   //用来获取父组件传递过来的所有属性
// console.log(vm.$attrs);

vm.$listeners   //用来获取父组件传递过来的所有方法
// console.log(vm.$listeners);

vm.$slots   //组件中的插槽
// console.log(vm.$slots);

vm.$scopedSlots     //用来访问作用域插槽
// console.log(vm.$scopedSlots);

vm.$refs    //用来定位DOM元素(使用ref进行追踪)
// console.log(vm.$refs);

vm.$watch   //用于监听数据(在vue文件中使用后会自动销毁)
// console.log(vm.$watch);

vm.$emit    //用于派发事件(常用于数据通信)
// console.log(vm.$emit);

vm.$on  //用于监听事件的派发
// console.log(vm.$on);

vm.$once    //只监听事件一次(之后不监听)
// console.log(vm.$once);

//生命周期
beforeCreate() {
}
created() {
}
beforeMount() {
}
mounted() {
}
beforeUpdate() {
}
updated() {
}
beforeDestroy() {
}
destroyed() {
}

(学习视频分享:vuejs教程web前端

위 내용은 Vue에서 일반적으로 사용되는 API는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.