美文网首页
render函数的学习:

render函数的学习:

作者: fyzm | 来源:发表于2018-12-02 21:39 被阅读0次

render函数的第一个参数:

<body>
<div id="app" >
    <child></child>
</div>

<script src="https://cdn.jsdelivr.net/npm/vue@2.5.16/dist/vue.js"></script>
<script>
  Vue.component('child',{
    render:function(createElement) {
      var domFun = function(){
        return {
          template:'<div>锄禾日当午</div>'
        }
    }
    return createElement(domFun());
    } 
  })
 var app= new Vue({
    el:'#app'
  })
</script>

</body>

render的第二个参数:

<body>
<div id="app" >
    <child></child>
</div>

<script src="https://cdn.jsdelivr.net/npm/vue@2.5.16/dist/vue.js"></script>
<script>
 Vue.component('child',{
   render:function(createElement) {
     return createElement({
       template:'<div>我是龙的传人</div>'
     },{
       'class':{
         foo:true,
         baz:false
       },
       style:{
         color:'red',
         fontSize:'16px'
       },
       
       attrs:{
         id:'foo',
         src:'http://baidu.com'
       },
       domProps:{
         innerHTML:'<span style="color:blue;font-size:18px" >我是蓝色</span>'
       }
     })
   }
 })
 var app = new Vue({
   el:"#app",
 })
</script>
</body>

render函数的第三个参数:

<body>
<div id="app" >
    <child></child>
</div>

<script src="https://cdn.jsdelivr.net/npm/vue@2.5.16/dist/vue.js"></script>
<script>
 Vue.component('child',{
   render:function(createElement) {
     return createElement('div',[
       createElement('h1','我是h1标题'),
       createElement('h6','我是h6标题')
     ])
   }
 });
 var app = new Vue({
   el:"#app",
 })
</script>

</body>

this.$slots在函数中应用:

render函数第三个参数存的就是VNODE

createElement('header',header)存的就是VNODE

var header = this.$slots.header;存的是VNODE的数组

<body>
<div id="app" >
    <my-component>
      <p>锄禾日当午</p>
      <p>汗滴河下苦</p>
      <H3 slot="header">我是标题</H3>
      <H5 slot="footer">我是文章的最后一段</H5>
    </my-component>
</div>

<script src="https://cdn.jsdelivr.net/npm/vue@2.5.16/dist/vue.js"></script>
<script>
 Vue.component('my-component',{
   render:function(createElement){
     var header = this.$slots.header;
     var main = this.$slots.default;
     var footer = this.$slots.footer;
     return createElement('div',[
         createElement('header',header),
         createElement('main',main),
         createElement('footer',footer)
     ]);
   }
 })
 var app = new Vue({
   el:"#app",
   data:{
     
   }
 })
</script>

</body>

render函数中使用props传递数据:

<body>
<div id="app" >
   <button @click = "switchShow">点击切换美女</button>{{show}}
</div>

<script src="https://cdn.jsdelivr.net/npm/vue@2.5.16/dist/vue.js"></script>
<script>
Vue.component('my-component',{
  props:['show'],
  render:function(createElement) {
    var imgsrc;
    if(this.show){
      imgsrc = 'img/001.jpg'
    }else{
      imgsrc = 'img/002.jpg'
    }
    return createElement('img',{
      attrs:{
        src:imgsrc
      },
      style:{
        width:'300px',
        height:'400px'
      }
    });
  }
}) 
 var app = new Vue({
   el:"#app",
   data:{
     show:false
   },
   methods:{
     switchShow:function(){
       this.show = !this.show
     }
   }
 })
</script>

</body>

v-model在render函数中的使用:

<body>
<div id="app" >
    <!--<my-component :name="name" @input="showName"></my-component>-->
    <my-component :name="name" v-model="name"></my-component>
    <br> {{name}}
</div>

<script src="https://cdn.jsdelivr.net/npm/vue@2.5.16/dist/vue.js"></script>
<script>
//需求:
    Vue.component('my-component',{
        render:function (createElement) {
            var self = this;//指的就是当前的VUE实例
            return createElement('input',{
                domProps:{
                    value: self.name
                },
                on:{
                    input:function (event) {
                        debugger
                        var a = this;
                        //此处的this指的是什么?指的就是window
                        self.$emit('input',event.target.value)
                    }
                }
            })
        },
        props:['name']
    })
    var app = new Vue({
        el:'#app',
        data:{
            name: 'JACK'
        }
        // methods:{
        //     showName:function (value) {
        //          this.name = value
        //     }
        // }
    })

</script>

</body>

作用域插槽在render函数中的应用:

<body>
<div id="app" >
    <my-component>
        <template scope = "prop">
          {{prop.text}} <br>
          {{prop.msg}}
        </template>
    </my-component>
</div>

<script src="https://cdn.jsdelivr.net/npm/vue@2.5.16/dist/vue.js"></script>
<script>
Vue.component('my-component',{
  render:function(createElement) {
    return createElement('div',this.$scopedSlots.default({
      text:'我是子组件传递过来的数据',
      msg:'scopeText'
    }))
  }
})
    var app = new Vue({
        el:'#app',
        data:{
        
        }

    })

</script>

</body>

函数化组件:

<div id="app" >
    <my-component value = "haha">

    </my-component>
</div>

<script src="https://cdn.jsdelivr.net/npm/vue@2.5.16/dist/vue.js"></script>
<script>
    Vue.component('my-component',{
        functional: true,//表示当前的vue实例无状态。无实例
        render:function (createElement,context) {
            return createElement('button',{
                on:{
                    click:function () {
                        debugger
                        var a = this;
                        console.log(context)
                        console.log(context.parent)
                        // alert(context.parent.msg)
                        // alert(context.props.value)
                        alert(this.value)//undefined
                    }
                }
            },'点击我学习context')
        },
        props:['value']

    })

    var app = new Vue({
        el:'#app',
        data:{
          msg:'我是父组件内容'
        }

    })

</script>

相关文章

  • Vue 学习笔记 render函数

    Vue 学习笔记 九 、render函数 9.1 render函数初步了解 template下只允许有一个子节点 ...

  • vue的render函数

    render函数的作用 我们自己使用render函数 render函数---通过initrender加入vm对象原...

  • render函数的学习:

    render函数的第一个参数: render的第二个参数: render函数的第三个参数: this.$slots...

  • VUE/MUI 项目小记

    render虚拟DOM构造函数 MUI上拉加载 render函数

  • vue中的render函数式组件

    问题:1、render函数是什么2、render函数怎么用 1. render函数是什么 简单的说,在vue中我们...

  • Vue render函数认识和使用

    1、认识render函数参数使用 (1)、 render函数的第一个参数 在render函数的方法中,参数必须是c...

  • vue渲染流程

    把模板转化成render函数 调用render函数产生虚拟节点,将虚拟节点插入到真实节点上 生成render函数方...

  • RN 错误大全

    这个错误的原因是render函数出错,具体就是在render函数里面写了注释,所以千万不要在render函数里写注...

  • React学习笔记2

    1.render函数对于props和state必须是纯函数 render函数不能改变props和state的属性,...

  • new Vue({ render: h => h(App), }

    render函数的作用 render: h => h(App) 是下面内容的缩写: 继续缩写 继续缩写 箭头函数 ...

网友评论

      本文标题:render函数的学习:

      本文链接:https://www.haomeiwen.com/subject/mrkjcqtx.html