前端高级技术框架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

目录
相关文章
|
3月前
|
前端开发 机器人 API
前端大模型入门(一):用 js+langchain 构建基于 LLM 的应用
本文介绍了大语言模型(LLM)的HTTP API流式调用机制及其在前端的实现方法。通过流式调用,服务器可以逐步发送生成的文本内容,前端则实时处理并展示这些数据块,从而提升用户体验和实时性。文章详细讲解了如何使用`fetch`发起流式请求、处理响应流数据、逐步更新界面、处理中断和错误,以及优化用户交互。流式调用特别适用于聊天机器人、搜索建议等应用场景,能够显著减少用户的等待时间,增强交互性。
670 2
|
3天前
|
开发框架 小程序 前端开发
圈子社交app前端+后端源码,uniapp社交兴趣圈子开发,框架php圈子小程序安装搭建
本文介绍了圈子社交APP的源码获取、分析与定制,PHP实现的圈子框架设计及代码编写,以及圈子小程序的安装搭建。涵盖环境配置、数据库设计、前后端开发与接口对接等内容,确保平台的安全性、性能和功能完整性。通过详细指导,帮助开发者快速搭建稳定可靠的圈子社交平台。
|
3月前
|
JavaScript 前端开发 Docker
前端全栈之路Deno篇(二):几行代码打包后接近100M?别慌,带你掌握Deno2.0的安装到项目构建全流程、剖析构建物并了解其好处
在使用 Deno 构建项目时,生成的可执行文件体积较大,通常接近 100 MB,而 Node.js 构建的项目体积则要小得多。这是由于 Deno 包含了完整的 V8 引擎和运行时,使其能够在目标设备上独立运行,无需额外安装依赖。尽管体积较大,但 Deno 提供了更好的安全性和部署便利性。通过裁剪功能、使用压缩工具等方法,可以优化可执行文件的体积。
167 3
前端全栈之路Deno篇(二):几行代码打包后接近100M?别慌,带你掌握Deno2.0的安装到项目构建全流程、剖析构建物并了解其好处
|
2月前
|
编解码 前端开发 JavaScript
从入门到精通:揭秘前端开发中那些不为人知的优化秘籍!
前端开发是充满无限可能的领域,从初学者到资深专家,每个人都追求更快、更稳定、更用户体验友好的网页。本文介绍了四大优化秘籍:1. HTML的精简与语义化;2. CSS的优雅与高效;3. JavaScript的精简与异步加载;4. 图片与资源的优化。通过这些方法,可以显著提升网页性能和用户体验。
25 3
|
2月前
|
机器学习/深度学习 自然语言处理 前端开发
前端神经网络入门:Brain.js - 详细介绍和对比不同的实现 - CNN、RNN、DNN、FFNN -无需准备环境打开浏览器即可测试运行-支持WebGPU加速
本文介绍了如何使用 JavaScript 神经网络库 **Brain.js** 实现不同类型的神经网络,包括前馈神经网络(FFNN)、深度神经网络(DNN)和循环神经网络(RNN)。通过简单的示例和代码,帮助前端开发者快速入门并理解神经网络的基本概念。文章还对比了各类神经网络的特点和适用场景,并简要介绍了卷积神经网络(CNN)的替代方案。
175 1
|
3月前
|
JavaScript 前端开发 Docker
前端的全栈之路Meteor篇(一):开发环境的搭建 -全局安装或使用容器镜像
本文介绍了如何搭建 Meteor 开发环境,包括全局安装 Meteor 工具和使用 Docker 镜像两种方法,以及创建和运行一个简单的 Meteor 项目的基本步骤。 Meteor 是一个全栈 JavaScript 框架,适用于构建实时 Web 应用程序。文章还提供了遇到问题时的解决建议和调试技巧。
114 3
|
3月前
|
人工智能 自然语言处理 运维
前端大模型应用笔记(一):两个指令反过来说大模型就理解不了啦?或许该让第三者插足啦 -通过引入中间LLM预处理用户输入以提高多任务处理能力
本文探讨了在多任务处理场景下,自然语言指令解析的困境及解决方案。通过增加一个LLM解析层,将复杂的指令拆解为多个明确的步骤,明确操作类型与对象识别,处理任务依赖关系,并将自然语言转化为具体的工具命令,从而提高指令解析的准确性和执行效率。
|
3月前
|
自然语言处理 资源调度 前端开发
前端大模型入门(四):不同文本分割器对比和效果展示-教你如何根据场景选择合适的长文本分割方式
本文详细介绍了五种Langchain文本分割器:`CharacterTextSplitter`、`RecursiveCharacterTextSplitter`、`TokenTextSplitter`、`MarkdownTextSplitter` 和 `LatexTextSplitter`,从原理、优缺点及适用场景等方面进行了对比分析,旨在帮助开发者选择最适合当前需求的文本分割工具,提高大模型应用的处理效率和效果。
247 1
|
3月前
|
机器学习/深度学习 人工智能 自然语言处理
前端大模型入门(三):编码(Tokenizer)和嵌入(Embedding)解析 - llm的输入
本文介绍了大规模语言模型(LLM)中的两个核心概念:Tokenizer和Embedding。Tokenizer将文本转换为模型可处理的数字ID,而Embedding则将这些ID转化为能捕捉语义关系的稠密向量。文章通过具体示例和代码展示了两者的实现方法,帮助读者理解其基本原理和应用场景。
619 1
|
3月前
|
人工智能 前端开发 JavaScript
前端大模型入门(二):掌握langchain的核心Runnable接口
Langchain.js 是 Langchain 框架的 JavaScript 版本,专为前端和后端 JavaScript 环境设计。最新 v0.3 版本引入了强大的 Runnable 接口,支持灵活的执行方式和异步操作,方便与不同模型和逻辑集成。本文将详细介绍 Runnable 接口,并通过实现自定义 Runnable 来帮助前端人员快速上手。