前端高级技术框架Vue2从入门安装到常见指令

简介: 前端高级技术框架Vue2从入门安装到常见指令

介绍

前端高级技术

前端一款是有频率很高的框架

原生js中的dom操作太繁琐

所以我们使用了vue框架 可以免除原生js中的dom操作 简化书写

基于MVVM思想

实现了数据的双向绑定 把编程的关注点放在数据上

框架是一个半成品软件 是一套可重用的 通用的 软件基础代码模型

基于框架进行开发 更加快捷 更加高效

配置

参考文档

Vue.js - 渐进式 JavaScript 框架 | Vue.js (vuejs.org)

下载网站

安装 — Vue.js (vuejs.org)

创建文件夹专门放入js文件

在js文件夹中放入vue.js--->

特性

代码展示

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
  <!--引入 vue 的标签-->
  <script src="js/vue.js"></script>
</head>
<body>
 
  <!--编写 视图层 的展示-->
    <div id="app"><!--代表现在 vue 接管的对象就是 id 是 app 的 div 标签里的-->
          <!--绑定 数据模型 message 数据模型中的内容会直接展示出来-->
          <input type="text" v-model="message">
          <!--通过一个表达式 代表我们要让数据模型直接展示出来-->
          {{message}}
    </div>
 
</body>
<script>
    //定义 vue 对象
   new Vue({
      el:"#app",//vue 接管 的区域
      data:{
        message:"Hello Vue"
      }
   })
</script>
</html>

效果

我们可以

直接将数据模型中的数据展示出来

因为我们使用了v-model这个指令

改变输入框内的数值 后面的展示数值也会变化

因为他们绑定的是同一个数据模型

因为vue的双向绑定性

视图层的数据变化改变数据模型 数据模型变化又会改变视图层的数据展示

常用指令

常用指令1

为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>
  <!--引入 vue 的标签-->
  <script src="js/vue.js"></script>
</head>
<body>
 
  <!--编写 视图层 的展示-->
    <div id="app"><!--代表现在 vue 接管的对象就是 id 是 app 的 div 标签里的-->
      
          <!--创建一个表单 把输入的数据绑定到数据模型上-->
          <input type="text" v-model="url" >
 
          <!--定义一个超链接的标签-->
          <!--两种书写方式 第二种方式比较简洁-->
          <a v-bind:href="url">访问</a>
          <a :href="url">访问</a>
    </div>
 
</body>
<script>
    //定义 vue 对象
   new Vue({
      el:"#app",//vue 接管 的区域
      //定义数据模型
      data:{
          url:"http://www.baidu.com"
      }
   })
</script>
</html>

效果展示

通过v-model 和 v-bind绑定的变量

必须在数据模型中声明

常用指令2

为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>
  <!--引入 vue 的标签-->
  <script src="js/vue.js"></script>
</head>
<body>
 
  <!--编写 视图层 的展示-->
    <div id="app"><!--代表现在 vue 接管的对象就是 id 是 app 的 div 标签里的-->
        <!--定义一个按钮 代表一个单击事件-->
        <input type="button" value="点我" v-on:click="handle()">
        <input type="button" value="点我" @click="handle()">
    </div>
 
</body>
<script>
    //定义 vue 对象
   new Vue({
      el:"#app",//vue 接管 的区域
      //定义数据模型
      data:{
          url:"http://www.baidu.com"
      },
      methods:{
        handle:function(){
          alert("为什么点我");
        }
      }
   })
 
</script>
</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>
  <!--引入 vue 的标签-->
  <script src="js/vue.js"></script>
</head>
<body>
 
  <!--编写 视图层 的展示-->
    <div id="app"><!--代表现在 vue 接管的对象就是 id 是 app 的 div 标签里的-->
        
      <!--让 vue 接管-->
      年龄 <input type="text" v-model="age">经判定 ,为:
      <span v-if="age<=35">年轻人 (35 岁及以下) </span>
      <span v-else-if="age>35&&age<60">中年人 (35-60)</span>
      <span v-else="age>=60">老年人 (60 及以上)</span>
 
      <br><br>
 
 
    </div>
 
</body>
<script>
    //定义 vue 对象
   new Vue({
      el:"#app",//vue 接管 的区域
      //定义数据模型
      data:{
         age:20
      },
      //定义函数
      methods:{
        
      }
   })
 
</script>
</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>
  <!--引入 vue 的标签-->
  <script src="js/vue.js"></script>
</head>
<body>
 
  <!--编写 视图层 的展示-->
    <div id="app"><!--代表现在 vue 接管的对象就是 id 是 app 的 div 标签里的-->
        
      <!--让 vue 接管-->
      年龄 <input type="text" v-model="age">经判定 ,为:
      
      <span v-show="age<=35">年轻人 (35 岁及以下) </span>
      <span v-show="age>35&&age<60">中年人 (35-60)</span>
      <span v-show="age>=60">老年人 (60 及以上)</span>
 
      <br><br>
 
 
    </div>
 
</body>
<script>
    //定义 vue 对象
   new Vue({
      el:"#app",//vue 接管 的区域
      //定义数据模型
      data:{
         age:20
      },
      //定义函数
      methods:{
        
      }
   })
 
</script>
</html>

展示的效果一样

区别

v-show渲染的是三个标签而v-if渲染的是选择到的标签

v-show渲染三个标签只不过

是用css里的display属性赋值none来让未满足条件的标签不显示

常用指令4

代码

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
  <!--引入 vue 的标签-->
  <script src="js/vue.js"></script>
</head>
<body>
 
  <!--编写 视图层 的展示-->
    <div id="app"><!--代表现在 vue 接管的对象就是 id 是 app 的 div 标签里的-->
     <div v-for="addr in addrs">{{addr}}</div>
 
 
    </div>
 
</body>
<script>
    //定义 vue 对象
   new Vue({
      el:"#app",//vue 接管 的区域
      //定义数据模型
      data:{
         addrs:["北京","上海","西安","成都","深圳"]
      },
      //定义函数
      methods:{
        
      }
   })
 
</script>
</html>

类似于javase中的lambda表达式

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
  <!--引入 vue 的标签-->
  <script src="js/vue.js"></script>
</head>
<body>
 
  <!--编写 视图层 的展示-->
    <div id="app"><!--代表现在 vue 接管的对象就是 id 是 app 的 div 标签里的-->
     <div v-for="(addr ,index) in addrs">{{index}} : {{addr}}</div>
 
 
    </div>
 
</body>
<script>
    //定义 vue 对象
   new Vue({
      el:"#app",//vue 接管 的区域
      //定义数据模型
      data:{
         addrs:["北京","上海","西安","成都","深圳"]
      },
      //定义函数
      methods:{
        
      }
   })
 
</script>
</html>

展示

个人号推广

博客主页

多多!-CSDN博客

Web后端开发

https://blog.csdn.net/qq_30500575/category_12624592.html?spm=1001.2014.3001.5482

Web前端开发

https://blog.csdn.net/qq_30500575/category_12642989.html?spm=1001.2014.3001.5482

数据库开发

https://blog.csdn.net/qq_30500575/category_12651993.html?spm=1001.2014.3001.5482

项目实战

https://blog.csdn.net/qq_30500575/category_12699801.html?spm=1001.2014.3001.5482

算法与数据结构

https://blog.csdn.net/qq_30500575/category_12630954.html?spm=1001.2014.3001.5482

计算机基础

https://blog.csdn.net/qq_30500575/category_12701605.html?spm=1001.2014.3001.5482

回忆录

https://blog.csdn.net/qq_30500575/category_12620276.html?spm=1001.2014.3001.5482

目录
相关文章
|
16天前
|
前端开发
【前端web入门第四天】02 CSS三大特性+背景图
本文详细介绍了CSS的三大特性:继承性、层叠性和优先级,并深入讲解了背景图的相关属性,包括背景属性、背景图的平铺方式、位置设定、缩放、固定以及复合属性。其中,继承性指子元素自动继承父元素的文字控制属性;层叠性指相同属性后定义覆盖前定义,不同属性可叠加;优先级涉及选择器权重,包括行内样式、ID选择器等。背景图部分则通过具体示例展示了如何设置背景图像的位置、大小及固定方式等。
236 91
|
16天前
|
前端开发
【前端web入门第四天】01 复合选择器与伪类选择器
本文档详细介绍了CSS中的复合选择器与伪类选择器。复合选择器包括后代选择器、子代选择器、并集选择器和交集选择器,能够更精确地定位和样式化元素。后代选择器用于选中某元素的所有后代,子代选择器仅选中直接子元素。并集选择器可为多个标签设置相同样式,而交集选择器则选中同时满足多个条件的元素。此外,还介绍了伪类选择器,如鼠标悬停效果和超链接的不同状态。
50 32
【前端web入门第四天】01 复合选择器与伪类选择器
|
23小时前
|
JSON 前端开发 JavaScript
不会webpack的前端可能是捡来的,万字总结webpack的超入门核心知识
该文章提供了Webpack的基础入门指南,涵盖安装配置、基本使用、加载器(Loaders)、插件(Plugins)的应用,以及如何通过Webpack优化前端项目的打包构建流程。
不会webpack的前端可能是捡来的,万字总结webpack的超入门核心知识
|
15天前
|
前端开发
【前端web入门第五天】03 清除默认样式与外边距问题【附综合案例产品卡片与新闻列表】
本文档详细介绍了CSS中清除默认样式的方法,包括清除内外边距、列表项目符号等;探讨了外边距的合并与塌陷问题及其解决策略;讲解了行内元素垂直边距的处理技巧;并介绍了圆角与盒子阴影效果的实现方法。最后通过产品卡片和新闻列表两个综合案例,展示了所学知识的实际应用。
27 11
|
15天前
|
前端开发
|
15天前
|
弹性计算 前端开发 容器
【前端web入门第六天】02 flex布局
Flex布局是一种现代CSS布局模式,通过给父元素设置`display: flex`,其子元素可自动挤压或拉伸。它包含弹性容器和弹性盒子,主轴默认为水平方向,侧轴为垂直方向。主轴对齐方式由`justify-content`属性控制,侧轴对齐方式包括`align-items`(针对所有子元素)和`align-self`(针对单个子元素)。修改主轴方向使用`flex-direction`属性,`flex`属性用于控制子元素在主轴上的伸缩比例。此外,`flex-wrap`属性允许子元素换行,而`align-content`属性则定义多行对齐方式。
|
15天前
|
前端开发
【前端web入门第五天】01 结构伪类选择器与伪元素选择器
本文介绍了CSS中的结构伪类选择器和伪元素选择器。结构伪类选择器如`nth-child`可根据元素结构关系进行选择,例如将列表中首个`&lt;li&gt;`元素背景设为绿色。伪元素选择器用于创建装饰性内容。
|
15天前
|
前端开发
【前端web入门第五天】02 盒子模型基础
本文档详细介绍了CSS中的盒子模型及其组成部分,包括内容区域、内边距、边框线和外边距。通过具体示例展示了如何设置边框线、内边距及外边距,并解释了尺寸计算方法和版心居中的技巧。内容丰富,示例清晰,有助于理解盒子模型在网页布局中的应用。
|
15天前
|
前端开发
【前端web入门第六天】01 CSS浮动
这是关于CSS布局第六天学习目标的介绍,主要解决多个`&lt;div&gt;`标签在同一行显示的问题,即一个在左边,另一个在右边。文中介绍了标准流、浮动及flex布局的概念,重点推荐使用flex布局。文章详细讲解了浮动的基本使用、布局技巧及清除浮动的方法,包括额外标签法、单伪元素法、双伪元素法和`overflow`隐藏法,并提供了示例代码帮助理解。
|
15天前
|
前端开发
前端web入门第四天】03 显示模式+综合案例热词与banner效果
本文档介绍了HTML中标签的三种显示模式:块级元素、行内元素与行内块元素,并详细解释了各自的特性和应用场景。块级元素独占一行,宽度默认为父级100%,可设置宽高;行内元素在同一行显示,尺寸由内容决定,设置宽高无效;行内块元素在同一行显示,尺寸由内容决定,可设置宽高。此外,还提供了两个综合案例,包括热词展示和banner效果实现,帮助读者更好地理解和应用这些显示模式。