欢迎莅临 SUN WU GANG 的园子!!!

世上无难事,只畏有心人。有心之人,即立志之坚午也,志坚则不畏事之不成。

  博客园 :: 首页 :: 博问 :: 闪存 :: 新随笔 :: 联系 :: 订阅 订阅 :: 管理 ::

组件:实现应用中--局部--功能--代码--和--资源--的集合(组件就是一块砖,哪里需要,哪里搬)

模块

  • 理解:向外提供特定功能的js程序,一般就是一个js文件
  • 为什么:js文件很多很复杂
  • 作用:复用js,简化js的编写,提高js运行效率

组件

  • 理解:用来实现局部特定功能效果的代码集合(html、css、js、image......)
  • 为什么:一个界面的功能很复杂
  • 作用:复用编码,简化项目编码,提高运行效率

模块化:当应用中的js都以模块化来编写的,那这个应用就是一个模块化的应用。

组件化:当应用中的功能都是多组件的方式来编写的,那么这个应用就是一个组件化的应用。

----------------------------------------------------组件----------------------------------------------------

非单文件组件:一个文件中包含N个组件。

单文件组件:一个文件中只包含 1 个组件。

组件使用步骤:定义组件==》注册组件==》组件应用

第一步:定义组件

//#region 创建组件
  const school = Vue.extend({
    template:
      '<div>'
      + ' <h3>学校名称:{{schoolName}}</h3>'
      + ' <h3> 学校地址:{{ schoolAddress }}</h3>'
      + ' <button @click="showInfo">点我提示学校信息</button>'
      + '</div>',
    data () {
      return {
        schoolName: '希望小学',
        schoolAddress: '西安/110号/希望小学',
      }
    },
    methods: {
      showInfo () {
        alert(this.schoolName + '/' + this.schoolAddress)
      }
    }
  })

第二步:注册组件

局部注册

//#region  root1 局部注册
  new Vue({
    el: '#root',
    data: {
      msg: '你好vue 组件|可复用',
    },
    // ---------------注册组件|局部注册---------------
    components: {
      // school: school,
      // student: student,
      // 上方代码等价于--可简写为如下代码
      school,
      student,

    },

  })

  //#endregion

全局注册

  //#region  全局注册组件,注意:注册全局组件代码书写位置,需放在 new Vue之前
  Vue.component('temp', temp)

第三步:组件应用

示例一(vm):

<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>计算属性</title>
  <script type="text/javascript" src="../../Js/vue.js"></script>
</head>

<body>
  <div id="root">
    <!-- <h3>学校名称:{{school.name}}</h3>
    <h3>学校地址:{{school.address}}</h3>
    <hr>
    <h3>学生姓名:{{student.name}}</h3>
    <h3>学生年龄:{{student.age}}</h3> -->
    <h3>学校名称:{{schoolName}}</h3>
    <h3>学校地址:{{schoolAddress}}</h3>
    <hr>
    <h3>学生姓名:{{studentName}}</h3>
    <h3>学生年龄:{{studentAge}}</h3>
  </div>
</body>

</html>
<script type="text/javascript">
  //console.log(vm)
  Vue.config.productionTip = false
  // ----------------------创建vm----------------------
  const vm = new Vue({
    el: '#root',
    data: {
      schoolName: '希望小学',
      schoolAddress: '西安/110号/希望小学',
      studentName: '心仪',
      studentAge: 6
      /* school: {
        name: '希望小学',
        address: '西安/110号/希望小学',
      },
      student:
      {
        name: '心仪',
        age: '6'
      } */

    },
  })
</script>

示例二(组件):局部注册

<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>计算属性</title>
  <script type="text/javascript" src="../../Js/vue.js"></script>
</head>

<body>
  <div id="root">
    {{msg}}
    <!-- 使用组件标签 -->
    <school></school>
    <school></school>
    <hr>
    <student></student>
  </div>
</body>

</html>
<script type="text/javascript">
  Vue.config.productionTip = false
  // ----------------------创建组件----------------------
  const school = Vue.extend({
    template:
      '<div>'
      + ' <h3>学校名称:{{schoolName}}</h3>'
      + ' <h3> 学校地址:{{ schoolAddress }}</h3>'
      + ' <button @click="showInfo">点我提示学校信息</button>'
      + '</div>',
    data () {
      return {
        schoolName: '希望小学',
        schoolAddress: '西安/110号/希望小学',
      }
    },
    methods: {
      showInfo () {
        alert(this.schoolName + '/' + this.schoolAddress)
      }
    }
  })

  const student = Vue.extend({
    template: '<div><h3>学生姓名:{{studentName}}</h3> <h3> 学生年龄:{{ studentAge }}</h3></div>',
    data () {
      return {
        studentName: '心仪',
        studentAge: 6
      }
    }
  })

  new Vue({
    el: '#root',
    data: {
      msg: '你好vue 组件|可复用',
    },
    // 注册组件|局部注册
    components: {
      // school: school,
      // student: student,
      // 上方代码等价于--可简写为如下代码
      school,
      student,

    },

  })

</script>

<!-- <script type="text/javascript">
  Vue.config.productionTip = false
  // ----------------------创建vm----------------------
  const vm = new Vue({
    el: '#root',
    data: {
      schoolName: '希望小学',
      schoolAddress: '西安/110号/希望小学',
      studentName: '心仪',
      studentAge: 6
      /* school: {
        name: '希望小学',
        address: '西安/110号/希望小学',
      },
      student:
      {
        name: '心仪',
        age: '6'
      } */

    },
  })
</script> -->

 示例二(组件):全局注册

<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>非单文件组件--全局注册</title>
  <script type="text/javascript" src="../../Js/vue.js"></script>
</head>

<body>
  <div id="root">
    {{msg}}
    <!-- 使用组件标签 -->
    <school></school>
    <school></school>
    <hr>
    <student></student>
    <hr>

    <temp></temp>
  </div>
  <div id="root2">
    {{msg}}
    <!-- 使用组件标签 -->
    <!-- <school></school> -->

    <temp></temp>
  </div>
</body>

</html>
<script type="text/javascript">
  Vue.config.productionTip = false
  //#region 创建组件
  const school = Vue.extend({
    template:
      '<div>'
      + ' <h3>学校名称:{{schoolName}}</h3>'
      + ' <h3> 学校地址:{{ schoolAddress }}</h3>'
      + ' <button @click="showInfo">点我提示学校信息</button>'
      + '</div>',
    data () {
      return {
        schoolName: '希望小学',
        schoolAddress: '西安/110号/希望小学',
      }
    },
    methods: {
      showInfo () {
        alert(this.schoolName + '/' + this.schoolAddress)
      }
    }
  })

  const student = Vue.extend({
    template: '<div><h3>学生姓名:{{studentName}}</h3> <h3> 学生年龄:{{ studentAge }}</h3></div>',
    data () {
      return {
        studentName: '心仪',
        studentAge: 6
      }
    }
  })

  //#endregion

  //#region  创建组件
  const temp = Vue.extend({
    template:
      '<div>'
      + '<h2>你好 Vue {{name}}</h2>'
      + '</div>',
    data () {
      return {
        name: 'tom 全局组件示例'
      }
    }
  })
  //#endregion

  //#region  全局注册组件,注意:注册全局组件代码书写位置,需放在 new Vue之前
  Vue.component('temp', temp)
  //#endregion

  //#region  root1 局部注册
  new Vue({
    el: '#root',
    data: {
      msg: '你好vue 组件|可复用',
    },
    // ---------------注册组件|局部注册---------------
    components: {
      // school: school,
      // student: student,
      // 上方代码等价于--可简写为如下代码
      school,
      student,

    },

  })

  //#endregion



  new Vue({
    el: '#root2',
    data: {
      msg: '你好vue roor2 组件|可复用',
    },
    /* // ---------------注册组件|局部注册---------------
    components: {
      // school: school,
      // student: student,
      // 上方代码等价于--可简写为如下代码
      school,
      student,

    }, */

  })

</script>

总结:

1.Vue中使用组件的步骤==》定义组件(也叫创建组件)==》注册组件==》使用组件(写组件标签)

2.如何定义一个组件==》

使用Vue.extend(options)创建,其中options和new Vue(options)几乎一样,但区别如下:

  1. el 不要写,因为最终所有的组件都要经过一个vm的管理。由vm中的el决定服务那个容器
  2. data必须写成函数,因为用于避免组件被复用时,数据存在引用关系

注:使用template可以配置组件结构。

3.如何注册组件

  1. 局部注册:使用 new Vue的时候传入 components选项
  2. 全局注册:使用Vue.component('组件名称',组件)

注意:

一:组件命名:

  1. 一个单词
    • 第一种写法:首字母大写componets:{School:s}可大写,和Vue开发者工具进行呼应
    • 第二种写法:首字母小写
  2. 多个单词
    • 第一种写法:使用类似 'my-school' :s方式命名、
    • 第二种写法:每个单词首字母大写(MySchool:s)——需要Vue脚手架支持

注:

  1. 组件名尽可能回避html中已有的元素名称
  2. 可以使用name配置项指定组件在开发者工具中呈现的名字  
    •   const student = ({
          name: 'component-name',
          template: '<div><h3>学生姓名:{{studentName}}</h3> <h3> 学生年龄:{{ studentAge }}</h3></div>',
          data () {
            return {
              studentName: '心仪',
              studentAge: 6
            }
          }
        }

二:关于组件标签

第一种写法:<test></test>

第二种写法:<test/>

注:不用使用脚手架时,<test/>会导致后续组件不能渲染。

三:简写方式

const school = Vue.extend(options) 可简写为 const school =options

  // const student = Vue.extend({
  //   template: '<div><h3>学生姓名:{{studentName}}</h3> <h3> 学生年龄:{{ studentAge }}</h3></div>',
  //   data () {
  //     return {
  //       studentName: '心仪',
  //       studentAge: 6
  //     }
  //   }
  // })

  // -----------等价于-----------

  const student = ({
    template: '<div><h3>学生姓名:{{studentName}}</h3> <h3> 学生年龄:{{ studentAge }}</h3></div>',
    data () {
      return {
        studentName: '心仪',
        studentAge: 6
      }
    }
  })

 

posted on 2024-03-06 10:25  sunwugang  阅读(32)  评论(0编辑  收藏  举报