ホームページ  >  記事  >  ウェブフロントエンド  >  Vue を最初から使用してレンダリングする

Vue を最初から使用してレンダリングする

php中世界最好的语言
php中世界最好的语言オリジナル
2018-06-08 13:56:071292ブラウズ

今回は、Vue render をゼロから使用する方法についてお届けします。次は、Vue render をゼロから使用する際の注意点です。

はじめに

Vue を開発に使用する場合、ほとんどの場合、テンプレートを使用して開発するのが簡単で便利で高速ですが、場合によっては、テンプレートが特殊なシナリオにはあまり適していないことがあります。そこで、レンダリング機能を使いこなすために、詳しく調べてみることにしました。以下に書かれていることが間違っていると思われる場合は、私とのやり取りが執筆の最大の動機ですので、ご指摘ください。

シナリオ

公式ウェブサイトで説明されているシナリオ レベルプロパティを通じて見出しタグを動的に生成するコンポーネントを書き始めると、すぐに次のように実装することを考えるかもしれません:

<script type="text/x-template" id="anchored-heading-template">
 <h1 v-if="level === 1">
  <slot></slot>
 </h1>
 <h2 v-else-if="level === 2">
  <slot></slot>
 </h2>
 <h3 v-else-if="level === 3">
  <slot></slot>
 </h3>
 <h4 v-else-if="level === 4">
  <slot></slot>
 </h4>
 <h5 v-else-if="level === 5">
  <slot></slot>
 </h5>
 <h6 v-else-if="level === 6">
  <slot></slot>
 </h6>
</script>
Vue.component('anchored-heading', {
 template: '#anchored-heading-template',
 props: {
  level: {
   type: Number,
   required: true
  }
 }
})

このシナリオでのテンプレートの使用は、最良の選択 : まず、コードが冗長です。タイトルの異なるレベルにアンカー要素を挿入するには、 を使用する必要があります。

テンプレートはほとんどのコンポーネントでうまく機能しますが、ここではあまりきれいではありません。そこで、render 関数を使用して上記の例を書き直してみましょう:

Vue.component('anchored-heading', {
 render: function (createElement) {
  return createElement(
   'h' + this.level,  // tag name 标签名称
   this.$slots.default // 子组件中的阵列
  )
 },
 props: {
  level: {
   type: Number,
   required: true
  }
 }
})

より単純かつ明確になります。簡単に言うと、このコードは非常に単純ですが、Vue のインスタンス プロパティに精通している必要があります。この例では、アンカー見出しの Hello world! など、slot 属性を使用せずにコンポーネントにコンテンツを渡すと、それらの子要素がコンポーネント インスタンスの $slots.default に格納されることを知っておく必要があります。

createElement パラメーターの概要

次に理解しておく必要があるのは、createElement 関数でテンプレートを生成する方法です。 createElement によって受け入れられるパラメーターは次のとおりです:

createElement(
 // {String | Object | Function}
 // 一个 HTML 标签字符串,组件选项对象,或者
 // 解析上述任何一种的一个 async 异步函数,必要参数。
 'p',
 // {Object}
 // 一个包含模板相关属性的数据对象
 // 这样,您可以在 template 中使用这些属性。可选参数。
 {
  // (详情见下一节)
 },
 // {String | Array}
 // 子节点 (VNodes),由 `createElement()` 构建而成,
 // 或使用字符串来生成“文本节点”。可选参数。
 [
  '先写一些文字',
  createElement('h1', '一则头条'),
  createElement(MyComponent, {
   props: {
    someProp: 'foobar'
   }
  })
 ]
)

データ オブジェクトの詳細

注意すべき点: テンプレート構文と同様に、v-bind:class および v-bind:style は、次のように特別に扱われます。 VNode データ オブジェクトでは、次の属性名が最上位のフィールドです。このオブジェクトを使用すると、innerHTML などの DOM プロパティのような通常の HTML 属性をバインドすることもできます (これは v-html ディレクティブを置き換えます)。

{
 // 和`v-bind:class`一样的 API
 'class': {
  foo: true,
  bar: false
 },
 // 和`v-bind:style`一样的 API
 style: {
  color: 'red',
  fontSize: '14px'
 },
 // 正常的 HTML 特性
 attrs: {
  id: 'foo'
 },
 // 组件 props
 props: {
  myProp: 'bar'
 },
 // DOM 属性
 domProps: {
  innerHTML: 'baz'
 },
 // 事件监听器基于 `on`
 // 所以不再支持如 `v-on:keyup.enter` 修饰器
 // 需要手动匹配 keyCode。
 on: {
  click: this.clickHandler
 },
 // 仅对于组件,用于监听原生事件,而不是组件内部使用
 // `vm.$emit` 触发的事件。
 nativeOn: {
  click: this.nativeClickHandler
 },
 // 自定义指令。注意,你无法对 `binding` 中的 `oldValue`
 // 赋值,因为 Vue 已经自动为你进行了同步。
 directives: [
  {
   name: 'my-custom-directive',
   value: '2',
   expression: '1 + 1',
   arg: 'foo',
   modifiers: {
    bar: true
   }
  }
 ],
 // Scoped slots in the form of
 // { name: props => VNode | Array<VNode> }
 scopedSlots: {
  default: props => createElement('span', props.text)
 },
 // 如果组件是其他组件的子组件,需为插槽指定名称
 slot: 'name-of-slot',
 // 其他特殊顶层属性
 key: 'myKey',
 ref: 'myRef'
}

条件付きレンダリング

上記の API については理解したので、実際に戦闘をしてみましょう。

前はこう書いてました

//HTML
<p id="app">
  <p v-if="isShow">我被你发现啦!!!</p>
</p>
<vv-isshow :show="isShow"></vv-isshow>
//js
//组件形式      
Vue.component('vv-isshow', {
  props:['show'],
  template:'<p v-if="show">我被你发现啦2!!!</p>',
});
var vm = new Vue({
  el: "#app",
  data: {
    isShow:true
  }
});

renderはこう書いてました

//HTML
<p id="app">
  <vv-isshow :show="isShow"><slot>我被你发现啦3!!!</slot></vv-isshow>
</p>
//js
//组件形式      
Vue.component('vv-isshow', {
  props:{
    show:{
      type: Boolean,
      default: true
    }
  },
  render:function(h){  
    if(this.show ) return h('p',this.$slots.default);
  },
});
var vm = new Vue({
  el: "#app",
  data: {
    isShow:true
  }
});

リストレンダリング

前はこう書いてましたが、v-forの場合はテンプレートをラベルで囲む必要があります

rreeeredendはこのように書かれていました

rreeev-model

whition以前の書き方JavaScript はパフォーマンスにおいて絶対的な優位性を持っており、エディターはそれを分析しているだけです。実際のプロジェクトに関しては、レンダリングにどの方法を選択するかは、プロジェクトと実際の条件に基づいて決定する必要があります。

この記事の事例を読んだ後は、その方法を習得したと思います。さらに興味深い情報については、php 中国語 Web サイトの他の関連記事に注目してください。

推奨読書:

json-server を使用してバックエンド データを作成する方法

vuex 状態管理の使用方法の詳細な説明

以上がVue を最初から使用してレンダリングするの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。