98、vue.js简单入门
本篇导航:
一、介绍与安装
vue是一套构建用户界面的JAVASCRIPT框架。与其它大型框架不同的是,Vue 被设计为可以自底向上逐层应用。Vue 的核心库只关注视图层,不仅易于上手,还便于与第三方库或既有项目整合。
1、安装
下载vue.js:https://cn.vuejs.org/v2/guide/installation.html
2、CDN
也可以不下载直接使用cdn
https://cdn.jsdelivr.net/npm/vue
3、引用
- <script src="vue.js"></script>
- <script src="https://cdn.jsdelivr.net/npm/vue"></script>
4、使用格式
{{}},里面可以放表达式
- <div id="app">
- //和django中模版渲染一样使用{{变量}}插入文本
- {{ message }}
- </div>
- <script>
- //实例化Vue
- var app = new Vue({
- //定位标签 表示在当前这个元素内开始使用VUE
- el: '#app',
- //变量
- data: {
- message: 'Hello Vue!'
- }
- })
- <script>
二、vue常用指令
指令:是带有V-前缀的特殊属性,通过属性来操作元素
1、v-text,v-html
v-text:可以在元素当中插入值
v-html:元素不中不仅可以插入文本,还可以插入标签
- <!DOCTYPE html>
- <html lang="en">
- <head>
- <meta charset="UTF-8">
- <title>Title</title>
- <script src="vue.js"></script>
- </head>
- <body>
- <div id="app">
- <p>{{msg}}</p>
- <p>{{80+2}}</p>
- <p>{{20>30}}</p>
- 我是:<h1 v-text="msg">{{str}}</h1>
- 你是:<h1 v-text="msg">2222222222222</h1>
- <h2 v-html="hd"></h2>
- <h2 v-html="str"></h2>
- </div>
- <script>
- new Vue({
- el: "#app", //表示在当前这个元素内开始使用VUE
- data:{
- msg: "我是老大",
- hd: "<input type='button' value='你是小三'>",
- str: "我要发财!"
- }
- })
- </script>
- </body>
- </html>
v-text,v-html
2、v-if,v-show
v-if:根据表达式的真假值来动态插入和移除元素
v-show:根据表达式的真假值来隐藏和显示元素
- <!DOCTYPE html>
- <html lang="en">
- <head>
- <meta charset="UTF-8">
- <title>Title</title>
- <script src="vue.js"></script>
- </head>
- <body>
- <div id="app">
- <p v-if="pick">我是刘德华</p>
- <p v-else>我是张学友</p>
- <p v-show="temp">我是赵本山</p>
- <p v-show="ok">你喜欢我吗?</p>
- </div>
- <script>
- var vm = new Vue({
- el: "#app",
- data:{
- pick: false,
- temp: true,
- ok: true
- }
- })
- window.setInterval(function(){
- vm.ok = !vm.ok;
- },1000)
- </script>
- </body>
- </html>
v-if,v-html
3、v-for
v-for:根据变量的值来循环渲染元素
- <!DOCTYPE html>
- <html lang="en">
- <head>
- <meta charset="UTF-8">
- <title>Title</title>
- <script src="vue.js"></script>
- <style>
- ul li{
- list-style: none;
- }
- </style>
- </head>
- <body>
- <div id="app">
- <ul>
- <li v-for="(item,index2) in arr">
- {{item}}: {{index2}}
- </li>
- </ul>
- <ul>
- <li v-for="(item,key,index) in obj">
- {{item}}: {{key}}:{{index}}
- </li>
- </ul>
- <ul>
- <li v-for="item in obj2">
- {{item.username}}
- {{item.age}}
- {{item.sex}}
- </li>
- </ul>
- <div v-for="i in 8">
- {{i}}
- </div>
- </div>
- <script>
- new Vue({
- el: "#app",
- data:{
- arr: [11,22,3344,55],
- obj: {a:"张三",b:"李四",c:"王大拿",d:"谢大脚"},
- obj2:[
- {username: "jason"},
- {age: 20},
- {sex: "male"}
- ],
- }
- })
- </script>
- </body>
- </html>
v-for
4、v-on
1)v-on:监听元素事件,并执行相应的操作
- <!DOCTYPE html>
- <html lang="en">
- <head>
- <meta charset="UTF-8">
- <title>Title</title>
- <script src="vue.js"></script>
- </head>
- <body>
- <div id="app">
- <ul>
- <li v-for="(item,index) in arr">
- {{item}}: {{index}}
- </li>
- </ul>
- <input type="button" value="点我吧!" @click="show()">
- </div>
- <script>
- new Vue({
- el: "#app",
- data:{
- arr: [11,22,33,44,55],
- ],
- },
- //监听的事件
- methods: {
- show: function () {
- this.arr.pop();
- }
- }
- })
- </script>
- </body>
- </html>
v-on
2)小实例:
- <!DOCTYPE html>
- <html lang="en">
- <head>
- <meta charset="UTF-8">
- <title>Title</title>
- <script src="vue.js"></script>
- <style>
- ul li{
- list-style: none;
- }
- </style>
- </head>
- <body>
- <div id="app">
- <ul>
- <li><input type="checkbox">苹果</li>
- <li><input type="checkbox">香蕉</li>
- <li><input type="checkbox">香梨</li>
- <li><input type="checkbox" v-on:click="create()">其它</li>
- <li v-html="htmlstr" v-show="test"></li>
- </ul>
- </div>
- <script>
- var vm = new Vue({
- el: "#app",
- data:{
- test: false,
- htmlstr: "<textarea></textarea>"
- },
- methods: {
- create: function () {
- this.test = !this.test;
- }
- }
- })
- </script>
- </body>
- </html>
动态生成html
- <!DOCTYPE html>
- <html lang="en">
- <head>
- <meta charset="UTF-8">
- <title>Title</title>
- <script src="vue.js"></script>
- <style>
- ul li{
- list-style: none;
- display: inline-block;
- border: 1px solid cornflowerblue;
- height:40px;
- line-height: 40px;
- width: 120px;
- text-align: center;
- }
- </style>
- </head>
- <body>
- <div id="mybox">
- <ul>
- <li>
- <span v-on:click="qh(true)">二唯码登录</span>
- </li>
- <li>
- <span v-on:click="qh(false)">邮箱登录</span>
- </li>
- </ul>
- <div v-show="temp">
- <img src="erma.jpg">
- </div>
- <div v-show="!temp">
- <form action="http://mail.163.com" method="post">
- <p><input type="email"></p>
- <p><input type="password"></p>
- <p><input type="submit" value="登录"></p>
- </form>
- </div>
- </div>
- <script>
- new Vue({
- el: "#mybox",
- data: {
- temp: true
- },
- methods: {
- qh: function (t) {
- this.temp = t
- }
- }
- })
- </script>
- </body>
- </html>
tag切换
3)v-on简写
- //标准书写:
- <input type="button" value="点我吧!" v-on:click="show()">
- //简写:
- <input type="button" value="点我吧!" @click="show()">
5、v-bind
1)v-bind:绑定元素的属性来执行相应的操作
- <!DOCTYPE html>
- <html lang="en">
- <head>
- <meta charset="UTF-8">
- <title>Title</title>
- <script src="vue.js"></script>
- <style>
- .bk_1{
- background-color: cornflowerblue;
- width: 200px;
- height: 200px;
- }
- .bk_2{
- background-color: red;
- width: 200px;
- height: 200px;
- }
- .bk_3{
- border: 5px solid #000;
- }
- </style>
- </head>
- <body>
- <div id="app">
- <a href="http://www.qq.com" v-bind:title="msg">腾讯</a>
- <div :class="bk"></div>
- <div :class="bk2"></div>
- <div :class="{bk_2:temp}">fdjjdjdkdkkeedd</div>
- <div :class="[bk2,bk3]">8888888888</div>
- </div>
- <script>
- var vm = new Vue({
- el: "#app", //表示在当前这个元素内开始使用VUE
- data:{
- msg: "我想去腾讯公司上班",
- bk:"bk_1",
- bk2:"bk_2",
- bk3:"bk_3",
- temp: false
- }
- })
- </script>
- </body>
- </html>
v-bind
2)简写
- //标准写法:
- <div v-bind:class="bk"></div>
- //简写:
- <div :class="bk"></div>
6、v-model
1)v-model:实现了数据和视图的双向绑定
- <!DOCTYPE html>
- <html lang="en">
- <head>
- <meta charset="UTF-8">
- <title>Title</title>
- <script src="vue.js"></script>
- <style>
- ul li{
- list-style: none;
- }
- </style>
- </head>
- <body>
- <div id="app">
- <input v-model="msg">
- <p>{{msg}}</p>
- <input type="button" value="变化" @click="change">
- </div>
- <script>
- new Vue({
- el: "#app",
- data:{
- msg: "aaaaa"
- },
- methods: {
- change: function () {
- this.msg = 8888888;
- }
- }
- })
- </script>
- </body>
- </html>
v-model
2)简单实现学生信息增删改:
- <!DOCTYPE html>
- <html lang="en">
- <head>
- <meta charset="UTF-8">
- <title>Title</title>
- <script src="vue.js"></script>
- <style>
- ul li{
- list-style: none;
- }
- .tds{
- height: 15px;
- width: 175px;
- }
- </style>
- </head>
- <body>
- <div id="app">
- <div>
- <input type="text" placeholder="姓名" v-model="username">
- <input type="text" placeholder="年龄" v-model="age">
- <input type="button" value="增加" @click="add">
- </div>
- <div>
- <table cellpadding="0" border="1">
- <tr v-for="(item,index) in arr">
- <td :class="td" v-if="arr[index].temp">{{item.username}}</td>
- <td :class="td" v-else><input v-model="msg_user"></td>
- <td :class="td" v-if="arr[index].temp">{{item.age}}</td>
- <td :class="td" v-else><input v-model="msg_age"></td>
- <td>
- <input type="button" value="删除" @click="del(index)">
- <input type="button" value="修改" @click="edit1(index)" v-show="arr[index].temp">
- <input type="button" value="确定" @click="edit2(index)" v-show="!arr[index].temp">
- </td>
- </tr>
- </table>
- </div>
- </div>
- <script>
- new Vue({
- el: "#app",
- data:{
- temp:true,
- td:"tds",
- username: "",
- age: "",
- arr: [],
- msg_user:"",
- msg_age:""
- },
- methods: {
- add: function () {
- this.arr.push({username:this.username, age:this.age, temp:this.temp});
- },
- del: function (index) {
- this.arr.splice(index,1);
- },
- edit1:function (index) {
- this.arr[index].temp = !this.arr[index].temp;
- this.msg_user = this.arr[index].username;
- this.msg_age = this.arr[index].age
- },
- edit2:function (index) {
- this.arr[index].temp = !this.arr[index].temp;
- this.arr[index].username = this.msg_user;
- this.arr[index].age = this.msg_age
- }
- }
- })
- </script>
- </body>
- </html>
当前行修改方式
- <!DOCTYPE html>
- <html lang="en">
- <head>
- <meta charset="UTF-8">
- <title>Title</title>
- <script src="vue.js"></script>
- <style>
- ul li{
- list-style: none;
- }
- .tipbox{
- width: 200px;
- height:200px;
- border: 1px solid cornflowerblue;
- position: absolute;
- background-color: #aaaaaa;
- top: 200px;
- left: 600px;
- }
- </style>
- </head>
- <body>
- <div id="app">
- <div>
- <input type="text" placeholder="姓名" v-model="username">
- <input type="text" placeholder="年龄" v-model="age">
- <input type="button" value="增加" @click="add">
- </div>
- <div>
- <table cellpadding="0" border="1">
- <tr v-for="(item,index) in arr">
- <td>{{item.username}}</td>
- <td>{{item.age}}</td>
- <td>{{index}}</td>
- <td><input type="button" value="删除" @click="del(index)"></td>
- <td><input type="button" value="修改" @click="showBox(index)"></td>
- </tr>
- </table>
- </div>
- <div class="tipbox" v-show="isShow">
- <p><input type="text" placeholder="姓名" v-model="m_username"></p>
- <p><input type="text" placeholder="年龄" v-model="m_age"></p>
- <p>
- <input type="button" value="确定" @click="save()">
- <input type="button" value="取消" @click="cancel()">
- </p>
- </div>
- </div>
- <script>
- new Vue({
- el: "#app", //表示在当前这个元素内开始使用VUE
- data:{
- username: "",
- age: "",
- arr: [],
- isShow:false,
- m_username: "",
- m_age: "",
- n: 0
- },
- methods: {
- add: function () {
- this.arr.push({username:this.username, age: this.age});
- },
- del: function (index) {
- this.arr.splice(index,1);
- },
- showBox: function (index) {
- this.isShow = true;
- this.n = index;
- this.m_username = this.arr[index].username;
- this.m_age = this.arr[index].age;
- },
- cancel: function () {
- this.isShow = false
- },
- save: function () {
- this.arr[this.n].username = this.m_username;
- this.arr[this.n].age = this.m_age;
- this.isShow = false
- }
- }
- })
- </script>
- </body>
- </html>
类模态框修改方式
7、自定义指令
特定指令无法满足我们的开发需求时可以自定义指令
当进入一个页面时,输入框获取焦点,且背景颜色是蓝色,字体颜色是白色:
- <!DOCTYPE html>
- <html lang="en">
- <head>
- <meta charset="UTF-8">
- <title>Title</title>
- <script src="vue.js"></script>
- <style>
- ul li{
- list-style: none;
- }
- </style>
- </head>
- <body>
- <div id="app">
- <input type="text" v-focus>
- </div>
- <script>
- new Vue({
- el: "#app", //表示在当前这个元素内开始使用VUE
- data:{
- },
- //自定义指令
- directives: {
- focus: { //指令的名字
- //当绑定的元素显示时
- inserted: function (tt) {
- tt.focus();
- tt.style.backgroundColor = "blue";
- tt.style.color = "#fff"
- }
- }
- }
- })
- </script>
- </body>
- </html>
自定义指令
8、computed计算属性
从前面的代码中可以了解{{}}中可以放表达式 但是当简单的表达式无法满足业务时就需要计算属性了
- <!DOCTYPE html>
- <html>
- <head>
- <meta charset="UTF-8">
- <title>Title</title>
- <script src="vue.js"></script>
- </head>
- <body>
- <div id="app">
- <p>{{msg}}</p>
- </div>
- <script>
- var vm = new Vue({
- el: "#app",
- data: {
- temp: 1001
- },
- //计算属性
- computed: {
- msg: function () {
- if(this.temp > 1000){
- return parseInt(this.temp/10)-1
- } else {
- return this.temp-1
- }
- }
- }
- })
- </script>
- </body>
- </html>
98、vue.js简单入门的更多相关文章
- 13、vue.js简单入门
本篇导航: 介绍与安装 vue常用指令 一.介绍与安装 vue是一套构建用户界面的JAVASCRIPT框架.与其它大型框架不同的是,Vue 被设计为可以自底向上逐层应用.Vue 的核心库只关注视图层, ...
- Vue.js简单入门
这篇文章我们将学习vue.js的基础语法,对于大家学习vue.js具有一定的参考借鉴价值,有需要的朋友们下面来一起看看. Vue.js是一个数据驱动的web界面库.Vue.js只聚焦于视图层,可以很容 ...
- vue.js 简单入门
转载自:http://blog.csdn.net/violetjack0808/article/details/51451672 <!DOCTYPE html> <html lang ...
- Vue的简单入门
Vue的简单入门 一.什么是Vue? vue.js也一个渐进式JavaScript框架,可以独立完成前后端分离式web项目 渐进式:vue可以从小到控制页面中的一个变量后到页面中一块内容再到整个页面, ...
- Vue.js+vue-element搭建属于自己的后台管理模板:Vue.js快速入门(二)
Vue.js+vue-element搭建属于自己的后台管理模板:Vue.js快速入门(二) 前言 上篇文章对Vue.js有了初步理解,接下来我们把Vue.js基础语法快速的过一遍,先混个脸熟留个印象就 ...
- EChart.js 简单入门
EChart.js 简单入门 最近有一个统计的项目要做,在前端的数据需要用图表的形式展示.网上搜索了一下,发现有几种统计图库. MSChart 这个是Visual Studio里的自带控件,使用比 ...
- Vue.js 快速入门
什么是Vue.js vue是法语中视图的意思,Vue.js是一个轻巧.高性能.可组件化的MVVM库,同时拥有非常容易上手的API.作者是尤雨溪,写下这篇文章时vue.js版本为1.0.7 准备 我推荐 ...
- Vue的理解:Vue.js新手入门指南----转
最近在逛各大网站,论坛,以及像SegmentFault等编程问答社区,发现Vue.js异常火爆,重复性的提问和内容也很多,楼主自己也趁着这个大前端的热潮,着手学习了一段时间的Vue.js,目前用它正在 ...
- Vue.js新手入门指南
最近在逛各大网站,论坛,以及像SegmentFault等编程问答社区,发现Vue.js异常火爆,重复性的提问和内容也很多,楼主自己也趁着这个大前端的热潮,着手学习了一段时间的Vue.js,目前用它正在 ...
随机推荐
- JAVA模板方法
package project01; abstract class MyRuntime{ public final void runtime(){ long starttime =System.cur ...
- thinkphp5使用PHPExcel导入Excel数据
安装PHPExcel扩展类 地址:https://github.com/PHPOffice/PHPExcel ①通过composer安装 ②手动下载, 放在项目的extend目录下 代码中引入 由于P ...
- 高效的CSS代码(1)
——阅读笔记,欢迎纠错 平时写CSS时常用的两个CSS文档(小杂感觉用的蛮喜欢,也是看了些书,尝试使用效果不错) /************CSS reset *********/ /******** ...
- [js高手之路] vue系列教程 - 事件专题(4)
本文主要讲解事件冒泡,事件绑定的简写,事件默认行为,按键码等一系列与事件相关的知识. 一.事件绑定的简写,@事件类型. 之前我的[js高手之路] vue系列教程 - vue的事件绑定与方法(2) 用 ...
- MNIST-NameError: name ‘input_data’ is not defined解决办法
在学习TensorFlow文档教程的时候, 在MNIST入门一节,发现直接运行下载MNIST数据集的代码会报错.原代码如下: import tensorflow.examples.tutorials. ...
- JAVA中的按值传递
Java中只有按值传递,没有按引用传递! 方法参数共有两种类型: 基本数据类型 对象引用 一:基本数据类型 首先看一个小例子: package chuandi; public class Test1 ...
- 表迁移工具的选型-复制ibd的方法
1.1. 场景 有的时候开放人员自己的库需要帮忙导一些数据,但是表的数据量又很大.虽然说使用mysqldump或mysqlpump也可以导.但是这耗时需要比较久. 记得之前建议开放人员可以直接使用na ...
- hive问题: For direct MetaStore DB connections, we don't support retries at the client level
已经配置好hive,mysql作为元数据的数据库.在hive中执行drop语句出错: drop table mytest; 错误提示如下: FAILED: SemanticException Unab ...
- vue中的checkbox全选和反选
前几天有个博客园的朋友问小颖,小颖之前写的vue2.0在table中实现全选和反选 .Vue.js实现checkbox的全选和反选,为什么他将里面的js复制下来,但是实现不了全选和反选.小颖当时看他 ...
- JavaScript基础知识(数据类型及转换、运算符)
9.数据类型 概念:表示当前存储的数据的分类(表示数字 - 整数和小数) u 原始类型(原始值) -----[typeof运算符:判断变量的原始类型] *number(数字):表示数字 ...