Vue基础

vue指令

内容绑定

v-text

设置标签的内容一般通过双大括号的表达式{{ }}去替换内容

{{ hello }}

v-html

与v-text类似区别在于html中的结构会被解析为标签设置元素的innerHTML,v-text只会解析文本

事件绑定

v-on

可以简写为@,绑定的方法在methods中

显示切换

v-show

原理是修改的元素的display实现隐藏,指令后的内容最终都会解析为布尔值

v-if

可以搭配v-else-if v-else使用

通过表达式来确认是否从dom树中删除

<body>
<!-- 开发环境版本,包含了有帮助的命令行警告 -->
<script src="https://cdn.jsdelivr.net/npm/vue@2/dist/vue.js"></script>
<div id="app">
<button v-show="imgNum != '0'" @click="changeNum">上一张</button>
<img :src="imgNum+'.jpg'" alt="" class="picSize">
<button>下一张</button>
</div> <script>
var app = new Vue({
el:"#app",
data:{
imgNum:"1"
},
methods:{
changeNum: function(){
let n = parseInt(this.imgNum);
n++;
n %= 3;
this.imgNum = n.toString();
}
}
})
</script>
</body>

属性绑定

v-bind

可以通过简写:属性名来绑定属性

列表循环

v-for

通常搭配数组一起使用,语法(item,index) in 数据

        <ul>
<li v-for="(item,index) in noteHistory">
{{ item }} <span v-show="item?true:false" @click="deleteHistory(index)">x</span>
</li>
</ul>

双向数据绑定

v-model

绑定数据和表单元素相关联

<body>
<!-- 开发环境版本,包含了有帮助的命令行警告 -->
<script src="https://cdn.jsdelivr.net/npm/vue@2/dist/vue.js"></script>
<div id="app">
<input type="text" v-model="message" @keyup.enter="updateList">
<ul>
<li v-for="(item,index) in noteHistory">
{{ item }} <span v-show="item?true:false" @click="deleteHistory(index)">x</span>
</li>
</ul>
<span v-show="noteHistory.length > 0 ">总条数:<strong> {{ noteHistory.length }} </strong> </span>
<button @click="clear" v-show="noteHistory.length > 0 ">清空</button>
</div> <script>
var app = new Vue({
el:"#app",
data:{
noteHistory:[],
message: ""
},
methods:{
updateList: function(){
this.noteHistory.push(this.message);
// 新增后清空message
this.message = "";
},
deleteHistory: function(index){
this.noteHistory.splice(index,1);
},
clear: function(){
this.noteHistory = [];
}
}
})
</script>
</body>

前期安装

  1. 我们的框架需要通过NPM来管理我们的NodeJs的包

    • 下载地址 https://nodejs.org/en 选择稳定版本
  2. Vue CLi是vue的脚手架,我们通过命令npm install -g@vue/cli创建一个项目vue create + 项目名称
  3. package.json所有的依赖包都在这里,我们可以通过npm install 安装
    • 通过npm run serve运行

组件开发

  1. 组件后缀名都是.vue
  2. 每个组件基本有三部分组成template标签中是组件的结构,script放入组件js代码,style是组件的样式代码
<template>
<div>
<h1>{{ question }}</h1>
</div>
</template>
<script>
export default{
name:"movie",
data:function(){
return {
question:"显示问题"
}
}
}
</script>

父组件传值props两种方法一种通过路由对象获取

第二种方法,需要在main.js中routes设置属性props:true,组件中在定义属性名称

//动态路由
[{path:'song/:id',component: Song, props:true}]
<template>
<div>
<!-- 第一种方法获取路由中的id-->
<h6>{{ $route.params.id }}</h6>
<!-- 第二种办法是设置props-->
<h6>{{ id }}</h6>
</div> </template> <script>
export default({
props:['id']
})
</script>

element.ui

安装npm i element-ui -s

方便使用我们可以在main.js里面全局import ElementUI from 'element-ui'

Axios:前端页面向服务器发起请求

安装

npm install axios

在项目的main.js中导入,同时设置请求baseUrl

import axios from 'axios'
axios.defaults.baseURL = "http://127.0.0.1:5000"
Vue.prototype.$http = axios

发送网络请求

第一个then后面跟着处理成功的情况,catch用来处理失败的情况,最后一个then总是会执行的。

get请求

axios.get(uri,{params:{ }}).then(function(response)){ }.catch(function(error){ }).then(function(){ })

post请求

axios.post(uri,{ }).then(function(response)){ }.catch(function(error){ })

在需要使用的网络请求的地方使用

export default {
name: 'App',
data(){
return {
name: "",
age: 0
}
},
components: {
HelloWorld,
movie
},
//网络请求一般在created里面做,在挂载的时候做
created:function(){
this.$http.post("/index",{"name":"Jack","age":30})
.then((response)=>{
console.log(response.data.name);
this.name = response.data.name;
this.age = response.data.age;
})
.catch((error)=>{
console.log(error.data.name);
console.log(error);
})
}
}

mockjs

npm install mockjs

在项目创建mock目录,新建index.js文件

//引入mock.js
import Mock from 'mockjs'
//使用mockjs
Mock.mock(RegExp('/index'),{"name":"MOCK","age":30})

在项目中main.js中导入就可以了,如果不想用了直接删掉main.js中导入的包即可

import './mock'

VueRouter

这是官方的路由组件,用来管理单页面的路由和组件的映射

安装npm install vue-router@3 (vue2)npm install vue-router@4 (vue3)

在需要管理的组件(.Vue)中做路由链接,需要使用路由站位标签

<template>
<div>
<h1>我的音乐</h1>
<!-- 声明路由链接-->
<router-link to="/my/song/1">歌曲1</router-link>
<router-link to="/my/song/2">歌曲2</router-link>
<router-link to="/my/song/3">歌曲3</router-link>
<!-- 路由需要站位标签-->
<router-view></router-view>
</div>
</template>

新建一个文件router,在文件下新建一个index.js

通过routes来控制路由和组件的映射:重定向、路由嵌套、动态路由

import VueRouter from "vue-router";
import Vue from "vue";
//把需要的组件导入进来
import Discover from '../components/Discover'
import Friend from '../components/Friend'
import My from '../components/My'
import Music from '../components/Music'
import Song from '../components/Song'
//将vuerouter注册为vue的插件
Vue.use(VueRouter)
// 执行属性与组件的对应关系
const router = new VueRouter({
routes:[
//首页重定向
{path:'/',redirect: Discover},
{path:'/discover',component: Discover,
//通过children来声明子路由,做路由嵌套/discover/music
children:[
{path:'music',component: Music}
]
},
{path:'/friend',component: Friend},
{path:'/my',component: My,children:
//动态路由
[{path:'song/:id',component: Song, props:true}]
}
]
})
//需要做一个导出
export default router

在项目的main.js中导入并且在Vue中添加上这个router

import router from './router'
Vue.config.productionTip = false
new Vue({
render: h => h(App),
//key和value名字一直可以就写一个key
router
}).$mount('#app')

Vue框架快速上手的更多相关文章

  1. Activiti工作流框架——快速上手

        一.前言 最近在做公司的OA,里面有用到工作流,公司用的是 jbpm4,感觉比较老,资料有点少,就先学学 新一点的 activiti  ㄟ(▔▽▔)ㄏ 首先工作流的概念是:工作流(Workfl ...

  2. Caliburn Micro框架快速上手(WP)

    一.使用nuget添加起始工程         二.修改App.xaml文件和App.xaml.cs文件     AppBootstrapper介绍: AppBootstrapper根据中文的直译可以 ...

  3. Vue.JS快速上手(组件生命周期)

    一.什么是组件 组成网页独立功能基本单元(片段), 复用.维护.性能, Vue.js中的组件就是一个Vue的实例,Vue中的组件包含data/methods/computed. 一个Vue.js的应用 ...

  4. Vue.JS快速上手(组件间的通信)

    前言 Vue采用的是组件化思想,那么这些组件间是如何通信的呢?下面详细介绍一下. 所谓组件间通信,不单单是我们字面上理解的相互传递数据,这里还包括一个组件访问另一个组件的实例方法等,如父组件通过ref ...

  5. Vue.JS快速上手(指令和实例方法)

    1.声明式渲染 首先,我们要知道Vue是声明式渲染,那啥是声明式渲染,我们只需要告诉程序我们想要什么结果,其他的交给程序来做.与声明式渲染相对的是命令式渲染,即命令我们的程序去做什么,程序就会跟着你的 ...

  6. Vue.JS快速上手(Vue-router 实现SPA 开发)

    一.什么是路由 URL -> 映射 -> 组件 Hash+onhashchange History.pushstate+replaceState+onpopstate 二.准备工作 组件 ...

  7. vue.js和vue-router和vuex快速上手知识

    vue.js和vue-router和vuex快速上手知识 一直以来,认为vue相比react而言,学习成本会更低,会更简单,但最近真正接触后,发现vue的各方面都有做一些客户化的优化,有一些亮点,但也 ...

  8. 快速上手最新的 Vue CLI 3

    翻译:疯狂的技术宅 原文:blog.logrocket.com/getting-sta- 概要:本文将指导你快速上手 Vue CLI 3,包括最新的用户图形界面和即时原型制作功能的使用步骤. 介绍 尤 ...

  9. 可靠通信的保障 —— 使用ACK机制发送自定义信息——ESFramework 通信框架4.0 快速上手(12)

    使用ESPlus.Application.CustomizeInfo.Passive.ICustomizeInfoOutter接口的Send方法,我们已经可以给服务端或其它在线客户端发送自定义信息了, ...

  10. 如何快速上手一个新技术之vue学习经验

    碰到紧急项目挪别人的vue项目过来直接改,但是vue是18年初看过一遍,18年底再来用,早就忘到九霄云外了,结果丢脸的从打开vue开始学,虽然之前在有道云笔记做了很多记录,然后没有系统整理.所以借这次 ...

随机推荐

  1. 【技术积累】Python中的NumPy库【二】

    NumPy库的主要类有哪些? NumPy库的主要类包括: ndarray:N维数组对象,是NumPy最重要的类之一.它是Python中数组的基本数据结构,可以进行高效的数学计算和数据处理操作. ufu ...

  2. Go语言中的结构体:灵活性与可扩展性的重要角色

    1. 引言 结构体是Go语言中重要且灵活的概念之一.结构体的使用使得我们可以定义自己的数据类型,并将不同类型的字段组合在一起,实现更灵活的数据结构.本文旨在深入介绍Go语言中的结构体,揭示其重要性和灵 ...

  3. 2023-06-25:redis中什么是缓存穿透?该如何解决?

    2023-06-25:redis中什么是缓存穿透?该如何解决? 答案2023-06-25: 缓存穿透 缓存穿透指的是查询一个根本不存在的数据,在这种情况下,无论是缓存层还是存储层都无法命中.因此,每次 ...

  4. 《最新出炉》系列初窥篇-Python+Playwright自动化测试-5-元素定位大法-上篇

    1.简介 说到元素定位,小伙伴或者童鞋们肯定会首先想到 selenium 的八大元素定位大法.同理Playwright也有自己的元素定位的方法.今天就给小伙伴或者童鞋们讲解和分享一下Playwrigh ...

  5. 搭载ChatGPT之后的表格插件又有哪些新的改变——Function calling增强

    摘要:本文由葡萄城技术团队于博客园原创并首发.葡萄城为开发者提供专业的开发工具.解决方案和服务,赋能开发者. 在<大火的ChatGPT与SpreadJS结合会有哪些意想不到的效果>一文中提 ...

  6. 反向代理后 location 被替换成本机域名。

    反向代理后 location 被替换成本机域名. 和上次写博客系统遇到的问题一样. 反向代理后,系统header中的location参数 域名自动被替换成本机域名了,本地测试没有问题,服务器反向代理就 ...

  7. 国标GB28181协议客户端开发(四)实时视频数据传输

    国标GB28181协议客户端开发(四)实时视频数据传输 本文是<国标GB28181协议设备端开发>系列的第四篇,介绍了实时视频数据传输的过程.通过解读INVITE报文中的SDP信息,读取和 ...

  8. 怎样优雅地增删查改(一):从0开始搭建Volo.Abp项目

    @ 目录 项目介绍 模块化 由框架实现的 需要实现的 创建项目 创建业务模块 配置引用和依赖 配置DbContext 创建实体和Dto 配置AutoMapper 软件系统中数据库或者持久层的基本操作功 ...

  9. 【NestJS系列】从Nest CLI开始入门

    初识Nest JS Nest 是一个渐进的 Node.js 框架,它可以在 TypeScript 和 JavaScript (ES6.ES7.ES8)之上构建高效.可伸缩的企业级服务器端应用程序. N ...

  10. Jedis 参数异常引发服务雪崩案例分析

    作者:vivo 互联网服务器团队 - Wang Zhi Redis 作为互联网业务首选的远程缓存工具而被大面积使用,作为访问客户端的 Jedis 同样被大面积使用.本文主要分析 Redis3.x 版本 ...