zoukankan      html  css  js  c++  java
  • 关于隐式创建vue实例实现简化弹出框组件显示步骤

    我们在使用vue写alert组件的时候,经常是定义了一个alert.vue,然后引入alert.vue,然后配置参数等等,非常繁琐,那有没有一种方式可以像window.alert("内容")那样简单调用呢?

    答案是有的,

    vue.extent会返回一个预设了部分选项的Vue实例构造器,既然是vue实例构造器 那我们理论上是可以像new Vue({})那样去new 这个extent实例的,vue还提供了$amount,表示挂在到节点上,这样我们理论上可以这样:

        var author = Vue.extend({
            template: "<p><a>helloe</a></p>"
          });
    
          function addEle(){
            new author({propsData:{author:"zhuwei"}}).$mount("#author");
          }
    

      我们通过调用addEle方法就动态在ID为author节点上渲染了一个vue(前提是html界面已经存在ID为author的节点),到现在为止好像没什么特别的,如果我们在addEle方法里面直接创建一个ID为author的节点呢

        function addEle(){
            var authorEle = document.createElement("div");
            authorEle.setAttribute("ID","author");
            document.body.appendChild(authorEle);
            new author().$mount("#author");
          }
    

      这样至少html部分我们不需要添加这个ID为author的节点了,然后因为是弹出框组件,所以我们需要暴露出一个属性显示用户希望显示的信息,这里面我们使用propsData,它可以在new vue({})的实例中指定属性值,vue本意说是为了方便测试,这里我们拿过来用来给我们的extent实例传递显示信息:

        function addEle(msg){
            var authorEle = document.createElement("div");
            authorEle.setAttribute("ID","author");
            document.body.appendChild(authorEle);
            new author({propsData:{author:msg}}).$mount("#author");
          }
    

      这样当用户想弹出框的时候,直接点击addEle("hello world")就可以弹出信息,当然具体的弹出框组件我并没有写,这里面只是说出设计思想,细节大家都可以实现

  • 相关阅读:
    实现一个WEBIM
    拼写纠错
    UML系列图用例图
    [bzoj1670][Usaco2006 Oct]Building the Moat
    [bzoj3626][LNOI2014]LCA
    转:用JS写的一个树型结构
    一个购物车中修改商品数量的实列
    网站访问统计在Global.asax中的配置的深入讨论
    转:JavaScript中的三级联动
    转:用Sql Server存储上载图片字体
  • 原文地址:https://www.cnblogs.com/mrzhu/p/8475794.html
Copyright © 2011-2022 走看看