Vue.js基础(一)

news/2024/7/24 12:30:18 标签: vue.js, javascript, 前端

目录

1、{{ }} 文本插值

2、v-html原始html

3、v-bind Attribute(属性)绑定\三元运算符

4、v-for列表渲染

5、v-on监听事件

6、事件调用方法

7、v-model表单的输入绑定  

8、Props组件交互

父传子

子传父

子传父总结


1、{{ }} 文本插值

<template>
  <div class="hello">
    <p>{{ msg }}</p>
  </div>
</template>

<script>
export default {
  data(){
    return {
      msg:"学习vue"
    }
  }

}
</script>

2、v-html原始html

一些html标签使用模板并不能够生成效果;比如下方示例 标签<a>,要使用v-html才能有效果。

双大括号会将数据解释为纯文本,而不是 HTML。若想插入 HTML,需要使用 v-html 指令:

 

<template>
  <div class="hello">
    <h2>学习vue:模板文件</h2>
    <p>{{ msg }}</p>
    <div>{{ rawHtml }}</div>
    <div v-html="rawHtml"></div>
  </div>
</template>

<script>
export default {
  data(){
    return {
      msg:"学习vue",
      rawHtml:"<a href='http://www.baidu.com'>百度</a>"
    }
  }

}
</script>

 

3、v-bind Attribute(属性)绑定\三元运算符

模板语法不能在html属性中使用,可以使用v-bind指令(可简写成:)

<template>
  <div class="hello">
    <h2>学习vue:模板文件</h2>
    <div v-bind:id="dynamicId"></div>
    <p>{{ num+10 }}</p>
    <p>{{ flag?"chensir":"江河" }}</p>
  </div>
</template>

<script>
export default {
  data(){
    return {
      dynamicId:10002,
      num:10,
      flag:true
    }
  }

}
</script>

4、v-for列表渲染

v-for 指令用于循环渲染列表,其中每个循环项需要唯一的 key 属性,以便 Vue.js 可以跟踪每个列表项的身份,从而在列表数据发生更改时准确地重新渲染列表,提高渲染效率。

v-for指令中的 item 表示数组中的每一个元素,而 index 表示其在数组中的下标; :key="item.id" 表示在循环中为每个列表项分配唯一的标识符,以防止在更新时产生性能问题。

  1. 需要绑定唯一的key
  2. In可以换成of
  3. 当没有id的时候,就要写成[v-for=”(item,index) in data” :key=”index”]

         当有id的时候,就可以写成[v-for=”item in data” :key=”item.id”] 

<template>
  <div class="hello">
    <h2>学习vue:列表渲染</h2>
    <ul>
      <li v-for="(item,index) in newsList" :key="item.id">
         {{ index+1 }}--- {{ item.title }}
      </li>
    </ul>
  </div>
</template>

<script>
export default {
  data(){
    return{
      newsList:[
        {
          id:1001,
          title:"学vue1"
        },
        {
          id:1002,
          title:"学vue2"
        },
        {
          id:1003,
          title:"学vue3"
        },
        {
          id:1003,
          title:"学vue3"
        }
      ]
    }
  }
 
}
</script>

5、v-on监听事件

v-on: 可简写为@

<template>
  <div class="hello">
    <h2>学习vue:监听事件</h2>
    <button v-on:click="counter+=1"> Add  {{counter}}</button>
  </div>
</template>

<script>
export default {
  data(){
    return{
      counter:0
    }
  }
 
}
</script>

6、事件调用方法

<template>
  <div class="hello">
    <h2>学习vue:监听事件</h2>
    <button v-on:click="counter+=1"> Add  {{counter}}</button>
    <button @click="clickHandle">操作消息的按钮</button>
   <p> {{ message }}</p>
   <button @click="say('hi')">say hi</button>
   <button @click="say('what')">say what</button>
   <ul>
    <li @click="clickItemHandle(item)" v-for="(item,index) in names" :key="index">{{ item }}</li>
   </ul>
  </div>
</template>

<script>
export default {
  data(){
    return{
      counter:0,
      message:"消息通知",
      names:["小红","小花","豆豆"]
    }
  },
  methods:{
    clickHandle(event){
      //调用data中字段用this
      this.message="消息被撤回了"
      console.log(event)
      event.target.innerHTML="点击之后"
    },
    say(data){
      console.log(data)
    },
    clickItemHandle(msg){
      console.log(msg)
    }
  }
 
}
</script>

7、v-model表单的输入绑定  

lazy:当失去光标时值才同步

trim:自动过滤输入的首尾空白字符

8、Props组件交互

Props是Vue.js中的一种属性传递方式,允许一级组件向下传递数据给它的子组件。在Vue中,所有的组件默认的数据是私有的,这也让每个组件的可维护性很高。但是,当我们需要在多个组件之间共享数据时,就需要使用Props。

使用Props需要注意以下几点:

属性是单向数据流,即父组件向子组件传递数据,子组件不能直接修改Props的值。

不应该在子组件中直接修改Props的值,这样会导致数据无法保持单向性。

如果需要修改Props传入的数据,在子组件中需要利用Vue提供的事件机制通知父组件修改数据。

需在vue.config.js中关闭eslint校验:lintOnSave: false

父传子

app.vue

<template>
  <MyComponent :title="title" :age="age" :names="names"></MyComponent>
</template>

<script>
// import HelloWorld from './components/HelloWorld.vue'
import MyComponent from './components/MyComponent.vue'

export default {
  name: 'App',
  data(){
    return{
      title:"从app传过来的",
      age:18,
      names:["花花","豆豆","牛牛"]
    }
  },
  components: {
    // HelloWorld,
    MyComponent
  }
}
</script>

 MyComponent.vue

<template>
    <h3>prop传递数据</h3>
    <p>{{ title }}</p>
    <p>age={{ age }}</p>
    <ul>
        <li v-for="(item,index) in names" :key="index">{{ item }}</li>
    </ul>
    
</template>

<script>
export default{
    props:{
        title:{
            type:String,
            default:""
        },
        age:{
            type:Number,
            default:0
        },
        names:{
            type:Array,
            //数组和对象必须使用函数进行返回
            default:function(){
                return []
            }
        }
    }
}

</script>

子传父

app.vue:

<template>
  <div id="app">
    <school :getSchoolName="getSchoolName"></school>
    <hr />
    <student @getStudentName="getStudentName"></student>
    <hr />
    <grade ref="Grade"></grade>
   
  </div>
</template>
 
<script>
import school from "./components/School.vue";
import student from "./components/Student.vue";
import grade from "./components/Grade.vue";
 
export default {
  name: "App",
  components: {
    school,
    student,
    grade,
  },
  methods: {
    //方法一:父组件给子组件一个方法,子组件接收该方法
    getSchoolName(name) {
      console.log("学校名称:", name);
    },
    //方法二:自定义事件,子组件使用$emit函数触发父组件绑定的事件
    getStudentName(name) {
      console.log("学生名称:", name);
    },
    //方法三:通过ref属性获取子组件实例对象
    getGrade(grade){
         console.log("数学成绩:",grade );
    }
  },
  mounted() {
      this.$refs.Grade.$on("getGrade",this.getGrade)
  },
};
</script>
 

School.vue

<template>
  <div>
    学校名称{{ name }}, 学校地址{{ address }}
    <button @click="sendName">点我获取学校名称</button>
  </div>
</template>
 
<script>
export default {
  name: "School",
  props: ["getSchoolName"],
  data() {
    return {
      name: "北京大学",
      address: "北京",
    };
  },
  methods: {
    sendName() {
      this.getSchoolName(this.name);
    },
  },
};
</script>

Student.vue

<template>
  <div>
    学生姓名{{ name }}, 学生年龄{{ age }}
    <button @click="sendStudentName">点我获取学生姓名</button>
  </div>
</template>
 
<script>
export default {
  name: "Student",
  data() {
    return {
      name: "张三",
      age: 18,
    };
  },
  methods: {
    sendStudentName() {
      this.$emit("getStudentName", this.name);
    },
  },
};
</script>

Grade.vue

<template>
  <div>
    数学:{{ mathGrade }}
     <button @click="getGrade">点我获取数学成绩</button>
  </div>
</template>
 
<script>
export default {
  name: "Grade",
  data() {
    return {
      mathGrade: 99,
    };
  },
  methods: {
      getGrade(){
           this.$emit("getGrade",this.mathGrade)
      }
  },
};
</script>

子传父总结

方法一

 总结:子组件通过props属性接收父组件的方法,然后在子组件中调用父组件的方法以及传递参数。

<---父组件--->
 <school :getSchoolName="getSchoolName"></school>
 
<---子组件--->
export default {
  name: "School",
  props: ["getSchoolName"],
  data() {
    return {
      name: "北京大学",
      address: "北京",
    };
  },
  methods: {
    //子组件的一个点击事件
    sendName() {
       //由于接收到方法参数,所以可以直接调用
      this.getSchoolName(this.name);
    },
  },
};

方法二

总结:通过自定义事件,绑定到子组件实例对象上,然后在子组件中使用$emit方法触发自定义事件以及传参,父组件调用回调函数完成取值

<---父组件--->
<student @getStudentName="getStudentName"></student>
 
<---子组件--->
export default {
  name: "Student",
  data() {
    return {
      name: "张三",
      age: 18,
    };
  },
  methods: {
    //子组件的一个点击事件
    sendStudentName() {
    //通过$emit触发自定义事件(@后面的为触发的自定义事件)
      this.$emit("getStudentName", this.name);
    },
  },
};

 方法三

总结:通过ref属性,父组件获取到子组件实例对象,然后触发方法

<---父组件--->
 <grade ref="Grade"></grade>
 
//script中使用挂载函数:
  mounted() {
    //this.$refs.Grade表示获取到grade这个实例
    //$on()表示当……时候,第一个参数表示当调用getGrade函数的时候,第二个参数表示父组件中的回调函数
      this.$refs.Grade.$on("getGrade",this.getGrade)
  },
 
  methods:{
    //父组件的回调函数
    getGrade(grade){
         console.log("数学成绩:",grade );
    }
}
 
<---子组件--->
export default {
  name: "Grade",
  data() {
    return {
      mathGrade: 99,
    };
  },
  methods: {
      getGrade(){
        //使用方法和方法二中的类似
           this.$emit("getGrade",this.mathGrade)
      }
  },
};


http://www.niftyadmin.cn/n/5005032.html

相关文章

十六、MySQL常用函数有哪些?

1、函数 说到函数&#xff0c;就必须知道其本质是什么&#xff0c;在MySQL中&#xff0c;函数是指一段可以直接被另一段程序调用的程序或代码。 2、字符串函数 &#xff08;1&#xff09;函数 &#xff08;2&#xff09;字符串连接函数 字符串连接函数&#xff1a; select c…

【C++】atoi函数和itoa函数无废话极简概述

atoi和itoa这两个函数头文件均为<stdlib.h> atoi atoi全称&#xff1a;array to int&#xff0c;可以把字符串转换为整型 int atoi(const char *nptr); 使用演示&#xff1a; #1 char str[5]; cin>>str; int aatoi(str);#2 int a; aatoi("123");//a…

数学建模--多项式拟合方法Python实现

目录 1.算法设计思路 2.算法核心代码 3.算法效果展示 1.算法设计思路 算法关键步骤:(主要是利用到多项式拟合的库包) 1.将数据进行导入 2.进行曲线拟合返回值为各项系数 3.获得多项式拟合之后的函数表达式 4.将x代入表达式求出对应的y值(这样就能够表示出拟合的差别如何) 5.进…

学习Bootstrap 5的第六天

目录 信息警告框 警告框 实例 警告框链接 实例 关闭警告框 实例 警告框动画 实例 按钮 按钮样式 实例 按钮轮廓 实例 ​编辑按钮尺寸 实例 块级按钮 实例 实例 活动/禁用按钮 实例 加载器按钮 实例 扩展小知识 信息警告框 警告框 警告框是使用 .aler…

智能小车—PWM方式实现小车调速和转向

目录 1. 让小车动起来 2. 串口控制小车方向 3. 如何进行小车PWM调速 4. PWM方式实现小车转向 1. 让小车动起来 电机模块开发 L9110s概述 接通VCC&#xff0c;GND 模块电源指示灯亮&#xff0c; 以下资料来源官方&#xff0c;具体根据实际调试 IA1输入高电平&#xff0c…

软考高级系统架构设计师系列案例考点专题一:软件架构设计考点梳理及精讲

软考高级系统架构设计师系列案例考点专题一:软件架构设计考点梳理及精讲 一、质量属性判断与质量属性效用树二、必备概念三、架构风格对比四、MVC架构五、J2EE架构六、面向服务的架构SOA七、企业服务总线ESB系统架构设计师方面的知识在案例分析中每年必考1~2题,并且是第一题…

月报总结|Moonbeam 8月份大事一览

夏日已经趋近尾声&#xff0c;脚下的这片土地正迎来凉爽的秋天。Moonbeam在最炎热的8月中&#xff0c;依然朝着其愿景不断向前迈进。Moonbeam生态也迎来了许多好消息&#xff0c;先前启动的第二批生态Grant计划也完成了最后的链上投票&#xff0c;3个项目成功通过投票&#xff…

Docker的简介及安装

[shouce]http://shouce.jb51.net/docker_practice/栾一峰菜鸟教程参考文献 1 环境配置的难题 软件开发最大的麻烦事之一&#xff0c;就是环境配置。用户计算机的环境都不相同&#xff0c;你怎么知道自家的软件&#xff0c;能在那些机器跑起来&#xff1f; 用户必须保证两件事…