二、Vue组件化编程

这篇具有很好参考价值的文章主要介绍了二、Vue组件化编程。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

2、Vue组件化编程

二、Vue组件化编程,Vue,vue.js,javascript,前端

二、Vue组件化编程,Vue,vue.js,javascript,前端

2.1 非单文件组件

二、Vue组件化编程,Vue,vue.js,javascript,前端

<div id="root">
    <school></school>
    <hr>
    <student></student>
</div>
<script type="text/javascript">
    //创建 school 组件
    const school = Vue.extend({
        template: `
          <div>
              <h2>学校名称:{{ name }}</h2>
              <h2>学校地址:{{ address }}</h2>
          </div>
        `,
        data() {
            return {
                name: '学校',
                address: '河南'
            }
        }
    })
    //创建 student 组件
    const student = Vue.extend({
        template: `
          <div>
              <h2>学生姓名:{{ name }}</h2>
              <h2>学生年龄:{{ age }}</h2>
          </div>
        `,
        data() {
            return {
                name: '张三',
                age: '18'
            }
        }
    })
    const vm = new Vue({
        el: "#root",
        //注册组件
        components: {
            school: school,
            student: student
        }
    })
</script>
  • Vue中使用组件的三大步骤:
    • 定义组件(创建组件)
    • 注册组件
    • 使用组件(写组件标签)
  • 如何定义一个组件?
    • 使用Vue.extend(options)创建,其中optionsnew Vue(options)时传入的那个options几乎一样,但也有点区别;
      • 区别如下:
        • el不要写,为什么? ——— 最终所有的组件都要经过一个vm的管理,由vm中的el决定服务哪个容器。
        • data必须写成函数,为什么? ———— 避免组件被复用时,数据存在引用关系。
      • 使用template可以配置组件结构。
  • 如何注册组件?
    • 局部注册:靠new Vue的时候传入components选项
    • 全局注册:靠Vue.component(‘组件名’,组件)
  • 编写组件标签:
    • <school></school>

2.1.1 组件的注意点

几个注意点:
      1.关于组件名:
               一个单词组成:
                        第一种写法(首字母小写):school
                        第二种写法(首字母大写):School
               多个单词组成:
                        第一种写法(kebab-case命名):my-school
                        第二种写法(CamelCase命名):MySchool (需要Vue脚手架支持)
               备注:
                     (1).组件名尽可能回避HTML中已有的元素名称,例如:h2、H2都不行。
                     (2).可以使用name配置项指定组件在开发者工具中呈现的名字。

      2.关于组件标签:
               第一种写法:<school></school>
               第二种写法:<school/>
               备注:不用使用脚手架时,<school/>会导致后续组件不能渲染。

      3.一个简写方式:
               const school = Vue.extend(options) 可简写为:const school = options

2.2 组件的嵌套

<div id="root">

</div>
<script type="text/javascript">
    //定义一个student组件
    const student = Vue.extend({
        template: `
          <div>
          <h2>学生名字:{{ name }}</h2>
          <h2>学生年龄:{{ age }}</h2>
          </div>
        `,
        data() {
            return {
                name: '败落',
                age: 18
            }
        }
    })
    //定义一个school组件
    const school = Vue.extend({
        template: `
          <div>
          <h2>学校名称:{{ name }}</h2>
          <h2>学校地址:{{ address }}</h2>
          <student></student>
          </div>
        `,
        data() {
            return {
                name: '学校',
                address: '河南'
            }
        },
        components: {
            student: student
        }
    })
    //定义一个hello组件
    const hello = Vue.extend({
        template: `
          <h2>{{ msg }}</h2>
        `,
        data() {
            return {
                msg: '欢迎来学Vue'
            }
        }
    })
    //定义一个app组件
    const app=Vue.extend({
        template:`
          <div>
          <hello></hello>
          <school></school>
          </div>

        `,
        components:{
            hello:hello,
            school:school
        }
    })
    const vm = new Vue({
        template:`
        <app></app>
        `,
        el: "#root",
        components: {
            app:app
        }
    })
</script>

二、Vue组件化编程,Vue,vue.js,javascript,前端

二、Vue组件化编程,Vue,vue.js,javascript,前端

2.3 VueComonent

  • 关于VueComponent

    • school组件本质是一个名为VueComponent的构造函数,且不是程序员定义的,是Vue.extend生成的。

    • 我们只需要写<school/><school></school>Vue解析时会帮我们创建school组件的实例对象,即Vue帮我们执行的:new VueComponent(options)

      特别注意:每次调用Vue.extend,返回的都是一个全新的VueComponent!!!!

    • 关于this指向:

      • 组件配置中:
        • data函数、methods中的函数、watch中的函数、computed中的函数 它们的this均是【VueComponent实例对象】。
      • new Vue(options)配置中:
        • data函数、methods中的函数、watch中的函数、computed中的函数 它们的this均是【Vue实例对象】。
      • VueComponent的实例对象,以后简称vc(也可称之为:组件实例对象)。
      • Vue的实例对象,以后简称vm
<div id="root">
  <school></school>
  <hello></hello>
</div>
</body>

<script type="text/javascript">
  Vue.config.productionTip = false

  //定义school组件
  const school = Vue.extend({
    name:'school',
    template:`
				<div>
					<h2>学校名称:{{name}}</h2>
					<h2>学校地址:{{address}}</h2>
					<button @click="showName">点我提示学校名</button>
				</div>
			`,
    data(){
      return {
        name:'学校',
        address:'北京'
      }
    },
    methods: {
      showName(){
        console.log('showName',this)
      }
    },
  })

  const test = Vue.extend({
    template:`<span>atguigu</span>`
  })

  //定义hello组件
  const hello = Vue.extend({
    template:`
				<div>
					<h2>{{msg}}</h2>
					<test></test>
				</div>
			`,
    data(){
      return {
        msg:'你好啊!'
      }
    },
    components:{test}
  })


  // console.log('@',school)
  // console.log('#',hello)

  //创建vm
  const vm = new Vue({
    el:'#root',
    components:{school,hello}
  })
</script>

二、Vue组件化编程,Vue,vue.js,javascript,前端

二、Vue组件化编程,Vue,vue.js,javascript,前端文章来源地址https://www.toymoban.com/news/detail-836133.html

到了这里,关于二、Vue组件化编程的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • VUE3 --->组件化

    目录 vue-cli 1、基于 vue ui 创建 vue 项目  组件库 1.vue 组件库 2.vue 组件库和 bootstrap 的区别 3. 最常用的 vue 组件库 4. Element UI axios 拦截器 1. 回顾:在 vue3 的项目中全局配置 axios 2. 在 vue2 的项目中全局配置 axios 3、拦截器 4. 配置请求拦截器 5、配置响应拦截器 proxy 跨域代理 1. 回

    2024年02月15日
    浏览(30)
  • 通用vue组件化登录页面

    1.首先建立一个login文件夹,在里面建立对应的login.vue文件 2.设置登录页面的背景图,在App.vue文件中使用router-view进行展示登录组件 3.先给App.vue的div元素设置高度100%,之后在login.vue里面去设置背景图 这里注意怎么使login组件垂直水平居中的样式 1.首先建立一个cpns的文件夹,里

    2024年02月09日
    浏览(29)
  • 【Vue】Vite 组件化开发

    1. 什么是组件化开发 组件化开发指的是:根据封装的思想,把页面上可重用的部分封装为组件,从而方便项目的开发和维护。 例如:https://gitee.com/vdpadmin/variant-form 所展示的效果,就契合了组件化开发的思想。用户可以通过拖拽组件的方式,快速生成一个页面的布局结构。

    2024年02月10日
    浏览(33)
  • Vue开发实战(03)-组件化开发

    对组件功能的封装,可以像搭积木一样开发网页。 Vue官方的示例图对组件化开发的形象展示。左边是一个网页,可以按照功能模块抽象成很多组件,这些组件就像积木一样拼接成网页。 [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-aS7Zk8tp-16862

    2024年02月08日
    浏览(86)
  • Vue 如何简单快速组件化

    为了简化拆分复杂的代码逻辑,和实现代码的组件化,封闭化。我们需要使用组件化的方法。我这里只讲解我感觉最优的组件化方法。 vue组件化总结 vue 单文件组件 子组件修改Props报错 vue 父组件调用子组件方法ref vue中组件的props属性(详) 使用Vue-cil搭建一个简单的Vue页面,

    2024年02月12日
    浏览(27)
  • 通用vue组件化展示列表数据

    1.首先先确定要展示的表格列名以及拿到所需要展示的数组数据 2.然后建立一个专门放el-table遍历的文件 3.在父组件中将数据列表数据存放在listData里面,然后传给子组件,子组件定义一个动态的列,通过遍历propList得到列名,然后也动态匹配prop,这样prop的值会去和listData进行匹

    2023年04月08日
    浏览(24)
  • vue~el-autocomplete实现组件化

    可以实现异步的数据拉取,从异步返回的数据中,选择需要的结果,并回显到文本框中。 回调列表,异步的方式获取数据列表,显示在列表框中 当选中某一项时,会触发这个方法,将数据获取到,这时,我们可以将数据回显,或者赋值给父页面上的元素,如果希望赋值父页

    2024年02月11日
    浏览(28)
  • Vue 组件化: 计算属性、内容分发、自定义事件

    目录 1. 计算属性 1.1 计算属性的特点 2. 内容分发 2.1 使用插槽的示例 3. 自定义事件 什么是计算属性 ? 计算属性的重点突出在 属性 两字, 首先它是个 属性 , 其次这个属性有 计算 的能力, 这里的计算就是个函数; 简单来说, 它就是一个能够将计算结果缓存起来的属性 (将行为转

    2024年02月08日
    浏览(36)
  • Vue:将以往的JQ页面,重构成Vue组件页面的大致思路梳理(组件化编码大致流程)

    组件要按照功能点拆分,命名不要与 HTML元 素冲突。 1、根据 UI 提供的原型图,进行结构设计,结构设计的粒度以是否方便给组件起名字为依据。并梳理好对应组件的层级依赖关系。 2、设计好结构后,开始写对应的组件,并根据梳理好的层级关系,对应引入组件。 3、根据

    2024年01月15日
    浏览(45)
  • 【vue3】10-vue组件化额外知识补充(下)-动态组件-组件缓存-v-model在组件上的应用

    切换组件案例: 比如我们现在想要实现了一个功能: 点击一个tab-bar,切换不同的组件显示; 这个案例我们可以通过两种不同的实现思路来实现: 方式一 :通过v-if来判断,显示不同的组件; 方式二 :动态组件的方式; 方式一代码示例: 动态组件方式实现 动态组件是使用 component组

    2024年02月08日
    浏览(54)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包