Vue(组件化编程:非单文件组件、单文件组件)

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

一、组件化编程

1. 对比传统编写与组件化编程(下面两个解释图对比可以直观了解)

传统组件编写:不同的HTML引入不同的样式和行为文件

Vue(组件化编程:非单文件组件、单文件组件)

组件方式编写:组件单独,复用率高(前提组件拆分十分细致) 

理解为封装行为:html,css,js封装在一个文件中

Vue(组件化编程:非单文件组件、单文件组件)

Vue(组件化编程:非单文件组件、单文件组件)

解释模块化和组件化的区别:

组件化:css,js,html三件套使用在同一部分的代码封装在一个组件中

模块化:只是将js文件进行拆分为多个文件

Vue(组件化编程:非单文件组件、单文件组件)

 文章来源地址https://www.toymoban.com/news/detail-430043.html

2. 组件化编程区分 

非单文件组件:一个文件中包含n个组件 

Vue(组件化编程:非单文件组件、单文件组件)

单文件组件:一个文件中只包含一个组件:后缀名是.vue(项目中多使用此方法)

Vue(组件化编程:非单文件组件、单文件组件)

3. 非单文件组件的引出 

使用两类数据进行划分组件包装部分,引出单文件组件的使用

  • 可以给每一部分进行划分并命名

  <div id="root">
      <h2>学校名称:{{schoolName}}</h2>
      <h2>学校地址:{{addrss}}</h2>
      <hr />
      <h2>学生名称:{{studentName}}</h2>
      <h2>学生年龄:{{age}}</h2>
  </div>
//vue数据
 const vm = new Vue({
      el: "#root",
      data: {
        schoolName: "清华",
        addrss: "北京",
        studentName: "李华",
        age: "18",
      },
  });

 Vue(组件化编程:非单文件组件、单文件组件)

 4. 单文件组件的使用

(1)局部注册(在vue配置项components中注册)

  • Vue.extend({}):创建组件(可以给此组件进行命名)

    • 出现很多配置项:但是几乎和Vue实例的配置项相同

    • const school = Vue.extend({})
    • 注意:此处不可以使用el绑定模板(template:``配置进行展示容器内容)

    • // el: "#root",//组件定义:一定不写el配置项:因为最终都要被vm管理,
      //由vm决定服务于哪个容器
      // 利用函数式写data:如果使用对象式,当其他模板调用时候修改也会修改原来的数据
       template: `
            <div>
              <h2>学校名称:{{schoolName}}</h2>
              <h2>学校地址:{{address}}</h2>
              <button @click="showName">点我提示学校名</button>
            </div>
            `,
    • 注意:此处的data使用的是函数式返回(不是对象式):因为多次一使用同一个组件,当后使用组件部分改变data中数据,前面组件使用组件的数据也会改变

    •   data() {
              return {
                schoolName: "清华",
                address: "北京",
              };
            },
  • components:{'组件名','...'} :注册组件(在Vue实例中使用此配置项):局部注册

 components: {
        // 完整写法:重新组件命名,创建组件的名字不是组件名,注册组建的名字才是组件名
        // xuexiao: school,
        // xueshneg: student,
        // 简写:相同的名字
        school,
        student,
      },
  • 组件标签:使用组件(将组件标签写在容器中,可以写多个组件标签=复用)

 <!-- 第三步编写组件标签 -->
      <school></school>
      <school></school>

给单文件组件添加事件:直接在组件的配置模板中绑定事件,并在组件中添加配置回调方法

(2)全局注册 :Vue.component('组件名',创建名)

创建组件并进行全局注册:此时的组件标签就可以在任何Vue绑定的模板中使用

 //1. hello全局组件创建
    const hello = Vue.extend({
      template: `
        <div>
        <h2>你好{{name}}</h2>
        </div>
      `,
      data() {
        return {
          name: "TOM",
        };
      },
    });
    
    
// 2. 全局注册组件(组件名字,组件在哪):可以使用在任何vue绑定的模板中
Vue.component("hello", hello);

 5. 单文件组建的注意点

  • 组件名:

    • 一个单词组件名:就是纯小写或者首字母大写(例如school、School)

    • 多个单词组件名:

      • kebab-case命名:my-school

      • CamelCase命名:MySchool(需要脚手架支持)

    • 备注:

      • 组件名回避html标签

      • 使用name配置项指定组件在开发者工具中呈现的名字(创建组件时候直接使用配置项name:进行命名=开发者工具中名字展示)

    • 组件标签:

      • 第一种写法:school组件标签写法 <school></school>

      • 第二种写法:<school/> (需要脚手架环境支持),以为不在脚手架环境复用多个组件标签只会渲染一个组件

    • 组件创建时候的简写方式:没有了extend()

    // 简写创建组件
    const school = {
      name: "xlf",
      template: `  <div>
         <h2>学校名称:{{name}}</h2>
         <h2>学校地址:{{address}}</h2>
       </div>`,
      data() {
        return {
          name: "xlf",
          address: "北京",
        };
      },
    };

 6. 组件的嵌套

以下展示说明大组件种包含着小组件也就是所谓的嵌套

Vue(组件化编程:非单文件组件、单文件组件)

 

  • 创建student子组件:必须在子组件创建好之后然后在父组件中注册

  • 创建school父组件:直接在此组件使用components(注册student,注册在哪里需要在那个模板中使用标签)

//子组件创建
 const student = Vue.extend({
      name: "student",
      template: `
			<div>
      <h2>学生姓名{{name}}</h2>
      <h2>学生年龄{{age}}</h2>
    	</div>
			`,
      data() {
        return {
          name: "德华",
          age: "18",
        };
      },
    });
//父组件创建并注册子组件(在负组件中使用子组件标签)
    const school = Vue.extend({
      name: "school",
      template: `
			<div>
      <h2>学校名称:{{name}}</h2>
      <h2>学校地址;{{address}}</h2>
			<student></student>
    	</div>
			`,
      data() {
        return {
          name: "清华",
          address: "北京",
        };
      },
      // 在组件内直接注册
      components: {
        student,
      },
    });
//最后总结在vue中
   new Vue({
      template: `<school></school>`,
      el: "#root",
      data: {},
      // 2.注册组件
      components: {
        school,
      },
    });

 开发中一创建app组件:管理所有组件(用法都是套娃)

 // 1.定义组件:注册给谁就在谁的模板上写组件标签
    const school = Vue.extend({
      name: "school",
      template: `
			<div>
      <h2>学校名称:{{name}}</h2>
      <h2>学校地址;{{address}}</h2>
			<student></student>
    	</div>
			`,
      data() {
        return {
          name: "清华",
          address: "北京",
        };
      },
      // 在组件内直接注册
      components: {
        student,
      },
    });
    // 定义app组件:注册亲子级组件,并及那个子级组件模板写入
    const app = Vue.extend({
      template: `
			<div>
      <hello></hello>
      <school></school>
      </div>
			`,
      components: {
        hello,
        school,
      },
    });

    new Vue({
      template: `<app></app>`,
      el: "#root",
      data: {},
      // 2.注册组件
      components: {
        app,
      },
    });

7. Vue.Component(组件实例化)

使用一个组件:进行了解Vue.Component

<div id="root">
      <!-- 3.使用标签 -->
      <school></school>
</div>

//vue
 // 1.定义组件school
    const school = Vue.extend({
      template: `
      <div>
      <h1>学校名称:{{name}}</h1>
      <h1>学校地址:{{address}}</h1>
    </div>
      `,
      data() {
        return {
          name: "清华",
          address: "北京",
        };
      },
});
new Vue({
      el: "#root",
      // 2.注册组件
      components: {
        school,
      },
});
  • 查看一下创建的组件:构造函数表示使用需要new一下(封装在源码)

  • 构造函数时Vue.extend生成的

  • 只需要使用组件标签就会创建组件实例=vc实例(使用两次组件标签就会实例化两次vc)

console.log(school);

Vue(组件化编程:非单文件组件、单文件组件)

 

  •  特别注意:每次调用Vue.extend就会创建一个全新的vc

  • 测试:在上面school组件基础上创建第二个个组件并对一个组件进行修改然后查看两个组件实例之间的区别

 // 定义组件hello
    const hello = Vue.extend({
      template: `
      <div>
      <h2>学校名称:{{msg}}</h2>
      <button @click="showName">点我显示学校名字</button>
    </div>
      `,
      data() {
        return {
          msg: "hello",
        };
      },
      methods: {
        showName() {
          console.log("showName", this);
        },
      },
    });
    // 检验VuComponent的不同
    school.a = 99;
    console.log(school === hello); //false
    console.log(school.a); //99
    console.log(hello.a); //没有

Vue(组件化编程:非单文件组件、单文件组件)

Vue(组件化编程:非单文件组件、单文件组件)

  •  this指向:
    • vm:vue的配置项中this指向的都是vm(Vue实例对象)
    • vc:组件中的配置项中this指向的都是vm(VueComponent实例对象)

 8. 重要的内置关系

组件是可复用的Vue实例

  • vc存在的属性配置vm都有

  • 但是vm存在的其中el,组件实例vc就没有

  • 并且组件中的data必须使用函数方式(return返回数据)

区分显示原型对象和隐式原型对象 

 // 定义构造函数
    function demo() {
      this.a = 1;
      this.b = 2;
    }
    const d = new demo();
    // 以下构造函数原型对象和实例对象原型对象最后都指向一个原型对象
    console.log(demo.prototype); //显示原型属性(一般放东西)
    console.log(d.__proto__); //隐式原型对象(一般开始找)
    console.log(demo.prototype === d.__proto__);//true
  //程序员通过显示原型属性操作原型对象,追加一个x属性,值为99
    demo.prototype.x = 99;

Vue(组件化编程:非单文件组件、单文件组件)

 

Vue.Component.prototype.__proto__===Vue.prototype 

Vue.Component原型对象的原型对象执行Vue原型对象

让组件实例对象那个vc可以访问到Vue原型上的属性、方法

Vue(组件化编程:非单文件组件、单文件组件)

 9. 单文件组件方式:.vue后缀

vue文件需要(处理加工变成js文件)两种处理方式

  • webpack:插件搭建工作流

  • vue脚手架

vue文件命名

Vue(组件化编程:非单文件组件、单文件组件)

 

 安装插件可以生成vue模板:<v  自动生成模板

Vue(组件化编程:非单文件组件、单文件组件)

 

<template>
  
</template>

<script>
export default {
//注意组件模块化引入,所以需要把js暴露

}
</script>

<style>

</style>

此处需要使用暴露方式把文件暴露出去:也就是允许其他文件引入

  • export :直接分别暴露:直接使用并取消组件的创建方法直接暴露optionsVue(组件化编程:非单文件组件、单文件组件)

  •  esprot {name}  :统一暴露

Vue(组件化编程:非单文件组件、单文件组件)

  •  默认暴露

Vue(组件化编程:非单文件组件、单文件组件)

 

(1) 创建两个组件:School组件、Student组件(这个类似)

<template>
  <div class="demo">
    <h2>学校名称:{{ schoolName }}</h2>
    <h2>学校地址:{{ address }}</h2>
    <button @click="showName">点我提示学校名</button>
  </div>
</template>

<script>
export default {
  name: "School",
  data() {
    return {
      schoolName: "清华",
      address: "北京",
    };
  },
  methods: {
    showName() {
      alert(this.schoolName);
      console.log(this); //指向当前组件
    },
  },
};
</script>

<style>
.demo {
  background-color: pink;
}
</style>

(2)引入组件文件并在app组件中嵌套注册:注意模板需要div包裹

<template>
  <div>
    <School></School>
    <Student></Student>
  </div>
</template>

<script>
// 先引入组件
import School from './School.vue'
import Student from './Student.vue'
// 再进行对外暴露并注册组件
export default {
  name: 'App',
  components: {
    School,
    Student
  }
}
</script>

<style>
</style>

(3) 组件分配完毕之后需要由vm统一管理

创建:main.js

  • 直接引入app组件

  • 绑定模板并注册app组件:注意在main模块中配置template配置项可以取消在html也买那种使用app标签进行组件实例

import App from './App.vue'
// 浏览器不支持模块化语法

new Vue({
	el: '#root',
	template:`<App></App>`,
	components: {App}
})

(4)需要容器:index.html与vue实例进行关联

  • 先创建模板

  • 引入vue文件

  • 引入main文件

  <div id="root"></div>
    <script src="../vue/vue.js"></script>
    <!-- 入口文件 -->
    <script src="./main.js"></script>

浏览器不能能直接支持ed6模块化语法:也就是引入模块化(需要配置脚手架环境进行运行)

Vue(组件化编程:非单文件组件、单文件组件)

 

到了这里,关于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学习Day3——生命周期\组件化

    Vue生命周期:就是一个Vue实例从 创建 到 销毁 的整个过程。 生命周期四个阶段:① 创建 ② 挂载 ③ 更新 ④ 销毁 1.创建阶段:创建响应式数据 2.挂载阶段:渲染模板 3.更新阶段:修改数据,更新视图 4.销毁阶段:销毁Vue实例 Vue生命周期过程中,会 自动运行一些函数 ,被称

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

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

    2024年02月08日
    浏览(54)

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

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

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

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

二维码1

领取红包

二维码2

领红包