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中的Microdata与历史记录管理详解

《HTML5中的Microdata与历史记录管理详解》Microdata作为HTML5新增的一个特性,它允许开发者在HTML文档中添加更多的语义信息,以便于搜索引擎和浏览器更好地理解页面内容,本文将探... 目录html5中的Mijscrodata与历史记录管理背景简介html5中的Microdata使用M

html5的响应式布局的方法示例详解

《html5的响应式布局的方法示例详解》:本文主要介绍了HTML5中使用媒体查询和Flexbox进行响应式布局的方法,简要介绍了CSSGrid布局的基础知识和如何实现自动换行的网格布局,详细内容请阅读本文,希望能对你有所帮助... 一 使用媒体查询响应式布局        使用的参数@media这是常用的

HTML5表格语法格式详解

《HTML5表格语法格式详解》在HTML语法中,表格主要通过table、tr和td3个标签构成,本文通过实例代码讲解HTML5表格语法格式,感兴趣的朋友一起看看吧... 目录一、表格1.表格语法格式2.表格属性 3.例子二、不规则表格1.跨行2.跨列3.例子一、表格在html语法中,表格主要通过< tab

Vue3组件中getCurrentInstance()获取App实例,但是返回null的解决方案

《Vue3组件中getCurrentInstance()获取App实例,但是返回null的解决方案》:本文主要介绍Vue3组件中getCurrentInstance()获取App实例,但是返回nu... 目录vue3组件中getCurrentInstajavascriptnce()获取App实例,但是返回n

JS+HTML实现在线图片水印添加工具

《JS+HTML实现在线图片水印添加工具》在社交媒体和内容创作日益频繁的今天,如何保护原创内容、展示品牌身份成了一个不得不面对的问题,本文将实现一个完全基于HTML+CSS构建的现代化图片水印在线工具... 目录概述功能亮点使用方法技术解析延伸思考运行效果项目源码下载总结概述在社交媒体和内容创作日益频繁的

前端CSS Grid 布局示例详解

《前端CSSGrid布局示例详解》CSSGrid是一种二维布局系统,可以同时控制行和列,相比Flex(一维布局),更适合用在整体页面布局或复杂模块结构中,:本文主要介绍前端CSSGri... 目录css Grid 布局详解(通俗易懂版)一、概述二、基础概念三、创建 Grid 容器四、定义网格行和列五、设置行

前端下载文件时如何后端返回的文件流一些常见方法

《前端下载文件时如何后端返回的文件流一些常见方法》:本文主要介绍前端下载文件时如何后端返回的文件流一些常见方法,包括使用Blob和URL.createObjectURL创建下载链接,以及处理带有C... 目录1. 使用 Blob 和 URL.createObjectURL 创建下载链接例子:使用 Blob

Vuex Actions多参数传递的解决方案

《VuexActions多参数传递的解决方案》在Vuex中,actions的设计默认只支持单个参数传递,这有时会限制我们的使用场景,下面我将详细介绍几种处理多参数传递的解决方案,从基础到高级,... 目录一、对象封装法(推荐)二、参数解构法三、柯里化函数法四、Payload 工厂函数五、TypeScript

Vue3使用router,params传参为空问题

《Vue3使用router,params传参为空问题》:本文主要介绍Vue3使用router,params传参为空问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录vue3使用China编程router,params传参为空1.使用query方式传参2.使用 Histo

CSS Padding 和 Margin 区别全解析

《CSSPadding和Margin区别全解析》CSS中的padding和margin是两个非常基础且重要的属性,它们用于控制元素周围的空白区域,本文将详细介绍padding和... 目录css Padding 和 Margin 全解析1. Padding: 内边距2. Margin: 外边距3. Padd