005 vue

2024-08-21 04:12
文章标签 javascript vue frontend 005

本文主要是介绍005 vue,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • vue常用指令
    • 01 vue-helloworld.html
    • 02 v-if与v-show.html
    • 03 v-on.html
    • 04 v-for.html
    • 05 v-bind.html
    • 06 v-model.html
  • vue的生命周期
  • vue组件化开发思想
  • 使用vue脚手架进行模块化开发
    • index.html
    • main.js
    • App.vue
    • Hello.vue
    • index.js

Vue官方文档
https://cn.vuejs.org/
Vue开源项目汇总
https://github.com/opendigg/awesome-github-vue
Vue.js中文社区
https://www.vue-js.com/

https://webpack.docschina.org/
https://vuejs-templates.github.io/webpack

npm install vue@2.6.12

vue常用指令

01 vue-helloworld.html

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title>
</head>
<body><div id="app"><!--获取vue对象中的data里面的值--><input type="text" v-model="num"/><button v-on:click="num++">点赞</button><button v-on:click="cancle">取消</button><h1>{{name}},开发好用,有{{num}}个开发者购买</h1></div>
</body><script src="./node_modules/vue/dist/vue.js"></script><script>let vm = new Vue({el: "#app",//绑定元素data: {//封装数据name: "macPro",num: 1},methods: {//封装方法cancle(){this.num --;}},});
</script></html>

02 v-if与v-show.html

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title>
</head>
<body><div id="app"><!-- 获取vue对象中data里的数据 --><p v-if="isShow">我是v-if数据</p><p v-show="isShow">我是v-show数据</p></div><!-- 引入vue.js文件 --><script src="../node_modules/vue/dist/vue.js"></script><script>let vm = new Vue({el: '#app',data: {isShow: false}});</script>
</body>
</html>

03 v-on.html

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title>
</head>
<body><div id="app"><button v-on:click="count++">增加1</button><!-- 对v-on指令,可以使用 @符号替代--><button @click="count++">增加1</button><!-- 调用add方法,当前count值+1--><button @click="add">增加1</button><!-- 调用total方法,传入当前的count值--><button @click="total(count)">执行total方法</button><!-- 点击回调只会触发一次--><button @click.once="doThis">只会触发一次</button><p>上面的按钮总被点击了{{count}}次</p></div>
</body>
<!-- 引入vue.js文件 -->
<script src="../node_modules/vue/dist/vue.js"></script>
<script>let vm = new Vue({el: '#app',data:{count:0},methods: {add:function(){this.count++;},total:function(num){console.log("累计点击次数"+num);console.log("total方法执行了");},doThis:function(){console.log("doThis方法执行了,只能执行一次");}}});
</script>
</html>

04 v-for.html

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title>
</head>
<body><div id="app"><p v-for="(item, index) in list">{{item}}----{{index}}</p><p v-for="person in persons">{{person.name}} --- {{person.age}} --- {{person.gender}}</p></div>
</body>
<!-- 引入vue.js文件--><script src="../node_modules/vue/dist/vue.js"></script><script>new Vue({el:'#app',data:{list:['迪丽热巴','古力娜扎','欧阳娜娜'],persons:[{name:'老王',age:38,gender:'男'},{name:'热巴',age:26,gender:'女'}]}});</script>
</html>

05 v-bind.html

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title>
</head>
<body><div id="app"><font size="5" v-bind:color="color1">拼多多</font><font size="5" :color="color2">京东</font><hr><a :href="'https://'+url">跳转网站</a></div>
</body>
<!-- 引入vue.js文件--><script src="../node_modules/vue/dist/vue.js"></script>
<script>let vm = new Vue({el:'#app',data:{color1: 'blue',color2: 'red',url:'www.jd.com'}});
</script>
</html>

06 v-model.html

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title>
</head>
<body><div id="app">用户名:<input type="text" id="username" v-model="user.username"><br>密 码:<input type="password" id="password" v-model="user.password"><br><input type="button" @click="func" value="提交数据"></div>
</body>
<!-- 加入vue.js文件--><script src="../node_modules/vue/dist/vue.js"></script><script>let vm = new Vue({el: '#app',data: {user: {username:'',password:''}},methods: {func(){console.log(this.user.username,this.user.password);//对数据的值 再次赋值进行更新this.user.username="tom123";this.user.password="456"}}});</script>
</html>

vue的生命周期

vue⽣命周期可以分为⼋个阶段,分别是:
beforeCreate(创建前)、created(创建后)、beforeMount(载⼊前)、mounted(载⼊后)、
beforeUpdate(更新前)、updated(更新后)、beforeDestroy(销毁前)、destroyed(销毁后)
如果想在⻚⾯加载完毕后就要执⾏⼀些操作的话,可以使⽤created和mounted钩⼦函数

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title>
</head><body><div id="app">{{message}}</div><script src="./node_modules/vue/dist/vue.js"></script><script>const vm = new Vue({el: '#app',data: {message: 'Vue的⽣命周期'},beforeCreate: function () {console.group('------beforeCreate创建前状态------');console.log("%c%s", "color:red", "el : " + this.$el);//undefinedconsole.log("%c%s", "color:red", "data : " +this.$data); //undefinedconsole.log("%c%s", "color:red", "message: " +this.message);//undefined},created: function () {console.group('------created创建完毕状态------');console.log("%c%s", "color:red", "el : " + this.$el);//undefinedconsole.log("%c%s", "color:red", "data : " +this.$data); //已被初始化console.log("%c%s", "color:red", "message: " +this.message); //已被初始化},beforeMount: function () {console.group('------beforeMount挂载前状态------');console.log("%c%s", "color:red", "el : " +(this.$el)); //已被初始化console.log(this.$el);console.log("%c%s", "color:red", "data : " +this.$data); //已被初始化 console.log("%c%s", "color:red", "message: " +this.message); //已被初始化 },mounted: function () {console.group('------mounted 挂载结束状态------');console.log("%c%s", "color:red", "el : " + this.$el);//已被初始化console.log(this.$el);console.log("%c%s", "color:red", "data : " +this.$data); //已被初始化console.log("%c%s", "color:red", "message: " +this.message); //已被初始化},beforeUpdate: function () {console.group('beforeUpdate 更新前状态===============》');console.log("%c%s", "color:red", "el : " + this.$el);console.log(this.$el);console.log("%c%s", "color:red", "data : " +this.$data);console.log("%c%s", "color:red", "message: " +this.message);},updated: function () {console.group('updated 更新完成状态===============》');console.log("%c%s", "color:red", "el : " + this.$el);console.log(this.$el);console.log("%c%s", "color:red", "data : " +this.$data);console.log("%c%s", "color:red", "message: " +this.message);},beforeDestroy: function () {console.group('beforeDestroy 销毁前状态===============》');console.log("%c%s", "color:red", "el : " + this.$el);console.log(this.$el);console.log("%c%s", "color:red", "data : " +this.$data);console.log("%c%s", "color:red", "message: " +this.message);},destroyed: function () {console.group('destroyed 销毁完成状态===============》');console.log("%c%s", "color:red", "el : " + this.$el);console.log(this.$el);console.log("%c%s", "color:red", "data : " +this.$data);console.log("%c%s", "color:red", "message: " +this.message)}})// 设置data中message数据值//vm.message = "good...";// 销毁Vue对象//vm.$destroy();</script>
</body></html>

vue组件化开发思想

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title>
</head>
<body><div id="app"><button v-on:click="count++">投币了{{count}}次</button><praise-button></praise-button><praise-button></praise-button><collect-button></collect-button><collect-button></collect-button></div>
</body><!-- 引入vue.js文件--><script src="./node_modules/vue/dist/vue.js"></script><script>//1.VUE全局声明一个组件Vue.component("praise-button",{template:'<button v-on:click="count++">点赞了{{count}}次</button>',data() {return {count:1}}});//2.VUE局部声明一个组件const collectButton = {template:'<button v-on:click="count++">收藏了{{count}}次-----</button>',data() {return {count:1}}}let vm = new Vue({el: '#app',data:{count:1},components:{//声明所定义的局部组件'collect-button':collectButton}});</script>
</html>

使用vue脚手架进行模块化开发

全局安装webpack依赖

npm install webpack -g

全局安装vue脚手架

npm install -g @vue/cli-init

创建⼀个⽂件夹在该路径下执⾏

vue init webpack my-project

运行项目

npm install
npm run dev

访问
http://localhost:8080

index.html

<!DOCTYPE html>
<html><head><meta charset="utf-8"><meta name="viewport" content="width=device-width,initial-scale=1.0"><title>my-project</title></head><body><div id="app"></div><!-- built files will be auto injected --></body>
</html>

main.js

// The Vue build version to load with the `import` command
// (runtime-only or standalone) has been set in webpack.base.conf with an alias.
import Vue from 'vue'
import App from './App'
import router from './router'Vue.config.productionTip = false/* eslint-disable no-new */
new Vue({el: '#app',router,components: { App },template: '<App/>'
})

App.vue

<template><div id="app"><img src="./assets/logo.png"><!--使用router-link组件来导航通过传入'to'属性指定链接<router-link>默认会被渲染成一个<a>标签--><router-link to="/">首页</router-link><router-link to="/Hello">去Hello</router-link><router-view/></div>
</template><script>
export default {name: 'App'
}
</script><style>
#app {font-family: 'Avenir', Helvetica, Arial, sans-serif;-webkit-font-smoothing: antialiased;-moz-osx-font-smoothing: grayscale;text-align: center;color: #2c3e50;margin-top: 60px;
}
</style>

Hello.vue

<template><div><h1>你好,hello,{{name}}</h1></div>
</template><script>
export default {data() {return {name: 'vue'}}
}
</script><style></style>

index.js

import Vue from 'vue'
import Router from 'vue-router'
import HelloWorld from '@/components/HelloWorld'
import Hello from '@/components/Hello'Vue.use(Router)export default new Router({routes: [{path: '/',name: 'HelloWorld',component: HelloWorld},{path: '/Hello',name: 'Hello',component: Hello}]
})

这篇关于005 vue的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1092084

相关文章

HTML5 getUserMedia API网页录音实现指南示例小结

《HTML5getUserMediaAPI网页录音实现指南示例小结》本教程将指导你如何利用这一API,结合WebAudioAPI,实现网页录音功能,从获取音频流到处理和保存录音,整个过程将逐步... 目录1. html5 getUserMedia API简介1.1 API概念与历史1.2 功能与优势1.3

全面解析HTML5中Checkbox标签

《全面解析HTML5中Checkbox标签》Checkbox是HTML5中非常重要的表单元素之一,通过合理使用其属性和样式自定义方法,可以为用户提供丰富多样的交互体验,这篇文章给大家介绍HTML5中C... 在html5中,Checkbox(复选框)是一种常用的表单元素,允许用户在一组选项中选择多个项目。本

HTML5 搜索框Search Box详解

《HTML5搜索框SearchBox详解》HTML5的搜索框是一个强大的工具,能够有效提升用户体验,通过结合自动补全功能和适当的样式,可以创建出既美观又实用的搜索界面,这篇文章给大家介绍HTML5... html5 搜索框(Search Box)详解搜索框是一个用于输入查询内容的控件,通常用于网站或应用程

CSS3中的字体及相关属性详解

《CSS3中的字体及相关属性详解》:本文主要介绍了CSS3中的字体及相关属性,详细内容请阅读本文,希望能对你有所帮助... 字体网页字体的三个来源:用户机器上安装的字体,放心使用。保存在第三方网站上的字体,例如Typekit和Google,可以link标签链接到你的页面上。保存在你自己Web服务器上的字

html 滚动条滚动过快会留下边框线的解决方案

《html滚动条滚动过快会留下边框线的解决方案》:本文主要介绍了html滚动条滚动过快会留下边框线的解决方案,解决方法很简单,详细内容请阅读本文,希望能对你有所帮助... 滚动条滚动过快时,会留下边框线但其实大部分时候是这样的,没有多出边框线的滚动条滚动过快时留下边框线的问题通常与滚动条样式和滚动行

使用vscode搭建pywebview集成vue项目实践

《使用vscode搭建pywebview集成vue项目实践》:本文主要介绍使用vscode搭建pywebview集成vue项目实践,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录环境准备项目源码下载项目说明调试与生成可执行文件核心代码说明总结本节我们使用pythonpywebv

使用Python和Tkinter实现html标签去除工具

《使用Python和Tkinter实现html标签去除工具》本文介绍用Python和Tkinter开发的HTML标签去除工具,支持去除HTML标签、转义实体并输出纯文本,提供图形界面操作及复制功能,需... 目录html 标签去除工具功能介绍创作过程1. 技术选型2. 核心实现逻辑3. 用户体验增强如何运行

CSS 样式表的四种应用方式及css注释的应用小结

《CSS样式表的四种应用方式及css注释的应用小结》:本文主要介绍了CSS样式表的四种应用方式及css注释的应用小结,本文通过实例代码给大家介绍的非常详细,详细内容请阅读本文,希望能对你有所帮助... 一、外部 css(推荐方式)定义:将 CSS 代码保存为独立的 .css 文件,通过 <link> 标签

使用Vue-ECharts实现数据可视化图表功能

《使用Vue-ECharts实现数据可视化图表功能》在前端开发中,经常会遇到需要展示数据可视化的需求,比如柱状图、折线图、饼图等,这类需求不仅要求我们准确地将数据呈现出来,还需要兼顾美观与交互体验,所... 目录前言为什么选择 vue-ECharts?1. 基于 ECharts,功能强大2. 更符合 Vue

Vue中插槽slot的使用示例详解

《Vue中插槽slot的使用示例详解》:本文主要介绍Vue中插槽slot的使用示例详解,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录一、插槽是什么二、插槽分类2.1 匿名插槽2.2 具名插槽2.3 作用域插槽三、插槽的基本使用3.1 匿名插槽