0. 先下载

1. 先写个轮廓

  • 不妨将下方轮廓记为 code1
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>code1</title>
<!-- 记得导入下载的 vue.js -->
<script type="text/javascript" src="./vue.js"></script>
<!-- * -->
</head>
<body>
<!-- 1 -->
<script type="text/javascript">
<!-- 2 -->
</script>
</body>
</html>

2. 牛刀小试

2.1 例子 1

  • step1
<!-- 在 code1 的 1 处创建容器 -->
<div id="app1">
{{msg}}
</div>
  • step2
// 在 code1 的 2 处创建 Vue 实例
new Vue({
el: "#app1", // el 是挂载点,用来挂载元素
data: { // 模板
msg: "你好"
}
});
  • 几个概念

    • 挂载点:Vue 只处理挂载点的内容
    • 模板:挂载点里面的内容
    • 实例:
      • new Vue()
      • 自动结合模板和数据,生成内容,将生成的内容发到挂载点

2.2 例子 2

  • step1
<!-- 在 code1 的 1 处,紧跟在 id="app1" 下面 -->
<div id="app2">
{{msg}}
</div>
  • step2
// 在 code1 的 2 处,紧跟着上一个 Vue 实例
var vm = new Vue({
el: "#app2",
data: {
msg: "数据"
}
});
  • 可以在控制台这样输入
> vm.msg = "姓名";
  • 控制台会返回
<· "姓名"
  • 与此同时,页面的第二行,原来的“数据”变为了“姓名”

    • 双向绑定:模板与视图中的数据会互相影响

3. 模板语法

  • 首先,取一个新的 code1(即,清空 code1 的 1 处与 2 处)

上例子

  • step1
<!-- 在 code1 的 1 处加入如下代码 -->
<div id="app">
<p>{{msg}}</p>
<p>{{str}}</p>
<p>{{obj}}</p>
<p>{{arr}}</p>
<p>{{1+1}}</p>
<p>{{1>0?'Y':'N'}}</p>
<!--
<p>{{var n = 1;}}</p>
[Vue warn]: Error compiling template: ...
-->
</div>
  • step2
// 在 code1 的 2 处加入如下代码
new Vue({
el: "#app",
data: {
msg: 12,
str: "34",
obj: {
name: "zhangsan",
age: 18
},
arr: [5, 6, 'a', 'b']
}
});
  • 上例说明

    • 模板中可以写的数据类型:字符串、对象、数组、简单运算
    • 不能写:表达式

4. 文本指令

  • 首先,取一个新的 code1

上例子

  • step1
<!-- 在 code1 的 1 处加入如下代码 -->
<div id="app">
<p v-html="msg"></p>
<p v-text="msg"></p>
</div>
  • step2
// 在 code1 的 2 处加入如下代码
new Vue({
el: "#app",
data: {
msg: "<h1>你好</h1>"
}
});
  • v-html 可以解析标签
  • v-text 不能解析标签

5. 属性操作

  • 首先,取一个新的 code1

上例子

  • step1
<!-- 在 code1 的 1 处加入如下代码

vue 1 版本可以这么用,但 2 版本改了
<a href={{url}}>百度</a> --> <!-- 完整写法 v-bind:href="url" -->
<a v-bind:href="url1">百度</a> <br> <!-- 简写(推荐) :href="url" -->
<a :href="url2" :title="msg">博客园</a>
  • step2
// 在 code1 的 2 处加入如下代码
new Vue({
el: "#app",
data: {
url1: "https://www.baidu.com",
url2: "https://www.cnblogs.com",
msg: "点我去博客园"
}
});
  • v-bind:属性名=""
  • 简写 :属性名=""

6. 样式操作

  • 首先,取一个新的 code1

上例子

  • step1
<!-- 在 code1 的 * 处加入 style -->
<style type="text/css">
.box1{
width: 200px;
height: 200px;
background: red;
}
.box2{
border: 3px solid green;
}
</style>
  • step2
<div id="app">
<div :class="[item1,item2]">1</div>
<div :class="{box1:true,box2:false}">2</div>
<div :class="{box1:flag,box2:flag}">3</div>
<!-- 会报错
<div v-bind:style="width:200px">4</div> -->
<div v-bind:style="{width:'200px',height:'200px',background:'red'}">4</div>
<div v-bind:style="{width:W,height:H,background:bg}">5</div>
<div v-bind:style="json">6</div>
<div v-bind:style="[json,b]">7</div>
</div>
  • step3
// 在 code1 的 2 处加入如下代码
new Vue({
el: "#app",
data: {
item1: "box1",
item2: "box2",
flag: true,
W: "200PX",
H: "200PX",
bg: "red",
json: {
width: "200px",
height: "200px",
background: "red"
},
b: {
border: "3px solid green"
}
}
});

类名的操作

  • 数组语法
v-bind:class=[变量名, 变量名]
data: {
变量名: 类名
}
  • 对象语法
v-bind:class={类名:true/false}

style 的操作

  • 数组语法
:style=[obj1, obj2]
data: {
obj1: {
width: '200px',
background: 'red'
},
obj2: {
border: '1px solid green'
}
}
  • 对象语法
:style={width:w}
data: {
w:'200px'
}

[Web 前端] 032 vue 初识的更多相关文章

  1. EasyDSS RTMP流媒体服务器web前端:vue组件之间的传值,父组件向子组件传值

    之前接触最多的都是EasyNVR,主要针对的都是前端的一些问题.也有接触到一些easydss流媒体服务器. 前端方面的,EasyDSS流媒体服务器与EasyNVR有着根本的不同.EasyNVR使用的是 ...

  2. EasyDSS高性能RTMP、HLS(m3u8)、HTTP-FLV、RTSP流媒体服务器web前端:vue组件之间的传值,父组件向子组件传值

    前端方面,EasyDSS流媒体服务器与EasyNVR有着根本的不同.EasyNVR使用的是传统的js来进行开发,而EasyDSS使用的是webpack+vue来进行开发的,了解vue+webpack的 ...

  3. [Web 前端] 033 Vue 的简单使用

    目录 0. 方便起见,定个轮廓 1. v-model 举例 2. v-for 举例 3. v-if 举例 4. 事件绑定 举例 5. v-show 举例 0. 方便起见,定个轮廓 不妨记下方的程序为 ...

  4. [Web 前端] 021 js 初识 Javascript

    1. Javascript 简介 1.1 定位 JS 是运行在浏览器端的脚本语言 1.1.1 关于浏览器 JS 由浏览器解释执行 JS 通常被直接嵌入 HTML 页面 1.1.2 关于脚本语言 JS ...

  5. React 还是 Vue: 你应该选择哪一个Web前端框架?

    学还是要学的,用的多了,也就有更多的认识了,开发中遇到选择的时候也就简单起来了. 本文作者也做了总结: 如果你喜欢用(或希望能够用)模板搭建应用,请使用Vue    如果你喜欢简单和“能用就行”的东西 ...

  6. Web前端-Vue.js必备框架(五)

    Web前端-Vue.js必备框架(五) 页面组件,商品列表组件,详情组件,购物车清单组件,结算页组件,订单详情组件,订单列表组件. vue-router 路由 vuex 组件集中管理 webpack ...

  7. Web前端-Vue.js必备框架(四)

    Web前端-Vue.js必备框架(四) 计算属性: <div id="aaa"> {{ message.split('').reverse().join('') }} ...

  8. Web前端-Vue.js必备框架(三)

    Web前端-Vue.js必备框架(三) vue是一款渐进式javascript框架,由evan you开发.vue成为前端开发的必备之一. vue的好处轻量级,渐进式框架,响应式更新机制. 开发环境, ...

  9. web前端框架之Vue hello world

    [博客园cnblogs笔者m-yb原创,转载请加本文博客链接,笔者github: https://github.com/mayangbo666,公众号aandb7,QQ群927113708] http ...

随机推荐

  1. rsyncd.conf配置文件

    rsyncd.conf配置文件     #Rsync server#created by oldboy 15:01 2009-6-5##rsyncd.conf start##uid = rootgid ...

  2. 对js数组去重的研究

    1.利用es5 let arr = [1, 2, 3, 4, 5, 6, 7, 1, 2, 3] const unique=arr=>{ return Array.from(new Set(ar ...

  3. Elastic-Job介绍

    1 什么是分布式任务调度 什么是分布式?当前软件的架构正在逐步转变为分布式架构,将单体结构分为若干服务,服务之间通过网络交互来完成用户的业务处理,如下图,电商系统为分布式架构,由订单服务.商品服务.用 ...

  4. sh_03_第1个函数

    sh_03_第1个函数 # 注意:定义好函数之后,之表示这个函数封装了一段代码而已 # 如果不主动调用函数,函数是不会主动执行的 def say_hello(): print("hello ...

  5. Spring 4.2.2以上版本和swagger集成方案和踩过的坑

    因为公司使用的spring版本太高,在集成swagger的时候会存在一些问题,而网上的很多实例大多都是版本比较低的,为了是朋友们少才坑,我这边将集成的过程记录一下: 1. 引入spring.swagg ...

  6. the path component: '/var' is world-writable

    java.io.IOException: the path component: '/var' is world-writable.  Its permissions are 0666.  Pleas ...

  7. controller大全(推荐)

    @Controller @RequestMapping("/router") @SessionAttributes(value = { "username" } ...

  8. hdu5988(费用流,对数相乘做加法)

    题意:一个网络流的图,有n个点,从1~n,然后m条边,每个点有两个值,一个是人的数量si一个是饭的数量bi.每条m边有容量ci,还有走上去可能踩断电线的概率pi(第一次踩上去没有事,之后都要p概率). ...

  9. 在vi vim中使用正则表达式与 普通perl正则的区别?

    参考这篇文章很好 vim中的正则表达式常用的命令有种, 即搜索和替换 /: 搜索 :s 替换 在vim中的正则表达式和perl编程的正则表达式还是有区别的: 正则表达式中的内容包括: 字面字符... ...

  10. 前端需要注意哪些SEO

    1.合理的title.description.keywords:搜索对这三项的权重逐个减小,title值强调重点即可,重要关键词不要超过2次,而且要靠前,不同页面title要有所不同:descript ...