热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

1Vue基础

Vue基础一、什么是Vue1.1概念Vue(读音vjuː,类似于view)是一套用于构建用户界面的渐进式JavaScript框架,与其它大型框架不

Vue基础


一、什么是Vue


1.1 概念


  • Vue (读音 /vjuː/,类似于 view) 是一套用于构建用户界面的渐进式Javascript框架,与其它大型框架不同的是,Vue 被设计为可以自底向上逐层应用。Vue 的核心库只关注视图层,不仅易于上手,还便于与第三方库或既有项目整合
    • 所谓渐进式,就是按需分配,用多少,就引入多少,由开发者自行决定
      • 既可以只使用Vue的核心功能,作为一个项目的视图层来应用
      • 也可以使用Vue全家桶开发,实现一个组件化、模块化、工程化的项目
    • Vue全家桶
      • vue-cli
        • vue-cli就是快速建立搭建一个vue项目的脚手架工具
      • vue-router
        • vue-router 是一个官方的路由管理器, 用于实现页面组件之间的跳转
      • vuex
        • vuex 是一个基于vue的状态管理模式,以方便的实现组件之间的数据共享和集中管理
      • axios
        • axios 是一个基于 promise 的 HTTP 库,是vue官方推荐的ajax异步请求工具
      • vant
        • Vant 是一个轻量、可靠的移动端UI组件库, 由有赞前端团队开发并维护
      • element-ui
        • element-ui 是一个基于vue的桌面端UI组件库, 由饿了么前端团队开发并维护
    • Vue中文官网
      • https://cn.vuejs.org/

1.2 特点


  • Vue 体积小,运行效率高,适合于移动/PC端开发

  • Vue简单易学,容易上手

  • Vue借鉴了angular的模板和数据绑定技术,可以轻松实现响应式编程

  • Vue借鉴了react的组件化技术,即提高了代码重用性,又易于维护和扩展性

  • Vue借鉴了react的虚拟DOM技术,采用diff算法实现页面更新,运行速度快


1.3 作者


  • Vue作者是尤雨溪

    • 尤雨溪,Vue.js和Vite的作者,HTML5版Clear的打造人,独立开源开发者。

    • 前Google员工,2014年2月,创作并开源了Vue.js

    • 2016年宣布加盟阿里巴巴Weex团队担任技术顾问

    • 尤雨溪大学专业并非是计算机专业,在大学期间他学习专业是室内艺术和艺术史,后来读了美术设计和技术的硕士,正是在读硕士期间,他偶然接触到了Javascript ,从此被这门编程语言深深吸引,开启了自己的前端生涯

      image-20210708001135078

1.4 版本


  • 2014年2月25日,发布0.9.0
  • 2015年10月27日,发布1.0.0
  • 2016年4月27日,发布2.0
  • 2020年9月18日晚 11 点半, 发布3.0.0
    • 为何不直接讲Vue3.0

      • 市场普及度不够,企业项目还是以2.X版为主
      • 新版本总会出现各种小错误,等反馈慢慢修复才会稳定
      • Vue3没有Vue2容易上手,掌握Vue2了再去学习Vue3会事半功倍

二、Vue起步


2.1 引入vue.js


  • 直接下载并用


3.6 v-bind


  • v-bind的基本用途是来绑定html元素属性,用法v-bind:属性名=“表达式”

  • v-bind:属性名

    • 可以简写为 :属性名

    <div id&#61;"app"><img v-bind:src&#61;"imgUrl"><img :src&#61;"imgUrl">
    div>
    <script>const vm &#61; new Vue({el: &#39;#app&#39;,data: { logo: &#39;https://cn.vuejs.org/images/logo.svg&#39;}})
    script>


3.7 v-model


  • 实现表单元素的双向数据绑定

    {{ message }}






3.8 v-if


  • v-if…v-else-if…v-else
    • vue中的条件指令可以根据条件在DOM中渲染或销毁元素/组件

      <p v-if&#61;"line &#61;&#61; 1">第一行....p>
      <p v-else-if&#61;"line &#61;&#61; 2">第二行....p>
      <p v-else>第三行....p>
      <script>const vm &#61; new Vue({el: &#39;#app&#39;,data: { line: 1}})
      script>


3.9 v-show


  • v-show的用法与v-if的用法基本一致&#xff0c;只不过v-show是改变元素的display属性进行显示和隐藏&#xff0c;当表达式的值为true时显示&#xff0c;为false时隐藏。

    <p v-show&#61;"line &#61;&#61; 1">第一行....p>
    <p v-show&#61;"line &#61;&#61; 2">第二行....p>
    <p v-show&#61;"line !&#61;&#61; 1 && line !&#61;&#61; 2">第三行....p>

    v-if和v-show的选择

    • v-if才是真正的条件渲染&#xff0c;它会根据条件表达式销毁或重建元素&#xff0c;
    • v-show只是简单的css的display属性的切换&#xff0c;实现的是元素的显示和隐藏
    • 相比之下&#xff0c;v-if更适合条件不经常改变的场景&#xff0c;因为它切换的开销相对较大&#xff0c;而v-show适合于频繁切换条件的场景

3.10 v-for


  • 当需要循环遍历时就会用来v-for指令&#xff0c;它的表达式需要结合in来使用。有些类似于原生js中for…in的用法

    <div id&#61;"app"><ul><li v-for&#61;"item in books" :key&#61;"item.id"><span>{{ item.name }}span> li>ul>
    div><script>const vm &#61; new Vue({el: &#39;#app&#39;,data: { books: [{id:&#39;001&#39;,name: &#39;三国演义&#39;},{id:&#39;002&#39;,name: &#39;水浒传&#39;},{id:&#39;003&#39;,name: &#39;西游记&#39;},{id:&#39;004&#39;,name: &#39;红楼梦&#39;},] }})
    script>

    v-for中的key属性&#xff1a;
    • 使用v-for更新已渲染的元素列表时,列表数据修改的时候,会根据key值去判断某个值是否修改,如果修改,则重新渲染这一项,否则复用之前的元素

作业&#xff1a;


  1. 请简单描述你对vue的理解

  2. 安装Vue Devtools

  3. 什么是MVVM

  4. 举例说是响应式数据的实现

  5. 举例说明10个Vue常见指令的作用

  6. 完成下图效果&#xff0c;输入任意字符串都转成相反顺序输出&#xff0c;比如“hello”转为“olleh”

    image-20210708053255262
  7. 思考题&#xff1a;使用vue实现如下学生信息录入系统

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-RD0aitQA-1651027041964)(images/image-20211129170957033.png)]


推荐阅读
  • 本文探讨了2019年前端技术的发展趋势,包括工具化、配置化和泛前端化等方面,并提供了详细的学习路线和职业规划建议。 ... [详细]
  • 基于Node.js、Express、MongoDB和Socket.io的实时聊天应用开发
    本文详细介绍了使用Node.js、Express、MongoDB和Socket.io构建的实时聊天应用程序。涵盖项目结构、技术栈选择及关键依赖项的配置。 ... [详细]
  • Vue项目中应用骨架屏实践
    在当前开发的项目中,由于登录过程涉及多次重定向,导致用户体验不佳。为了改善这一状况,本文介绍了如何使用vue-skeleton-webpack-plugin插件在Vue项目中实现骨架屏,以减少用户感受到的白屏时间。 ... [详细]
  • 本文详细介绍了 Dockerfile 的编写方法及其在网络配置中的应用,涵盖基础指令、镜像构建与发布流程,并深入探讨了 Docker 的默认网络、容器互联及自定义网络的实现。 ... [详细]
  • 帝国CMS多图上传插件详解及使用指南
    本文介绍了一款用于帝国CMS的多图上传插件,该插件通过Flash技术实现批量图片上传功能,显著提升了多图上传效率。文章详细说明了插件的安装、配置和使用方法。 ... [详细]
  • 本文探讨了领域驱动设计(DDD)的核心概念、应用场景及其实现方式,详细介绍了其在企业级软件开发中的优势和挑战。通过对比事务脚本与领域模型,展示了DDD如何提升系统的可维护性和扩展性。 ... [详细]
  • 当unique验证运到图片上传时
    2019独角兽企业重金招聘Python工程师标准model:public$imageFile;publicfunctionrules(){return[[[na ... [详细]
  • 本文深入探讨了JavaScript中实现继承的四种常见方法,包括原型链继承、构造函数继承、组合继承和寄生组合继承。对于正在学习或从事Web前端开发的技术人员来说,理解这些继承模式对于提高代码质量和维护性至关重要。 ... [详细]
  • C# 对象转 JSON 字符串的方法与应用
    本文介绍如何在 C# 中使用一般处理程序(ASHX)将对象转换为 JSON 字符串,并通过设置响应类型为 application/json 来确保客户端能够正确解析返回的数据。同时,文章还提供了 HTML 页面中不依赖 jQuery 的 AJAX 方法来接收和处理这些 JSON 数据的具体实现。 ... [详细]
  • Explore how Matterverse is redefining the metaverse experience, creating immersive and meaningful virtual environments that foster genuine connections and economic opportunities. ... [详细]
  • 深入解析ES6至ES8的新特性与应用
    本文详细介绍了自2015年发布的ECMAScript 6.0(简称ES6)以来,JavaScript语言的多项重要更新,旨在帮助开发者更好地理解和利用这些新特性进行复杂应用的开发。 ... [详细]
  • 本文探讨了局端设备与终端设备的基本概念及其在网络架构中的作用,详细分析了两者的工作原理、分类及应用场景。 ... [详细]
  • MikroTik RouterOS U盘安装工具netinstall详解及使用技巧
    本文详细介绍了如何使用MikroTik RouterOS的U盘安装工具netinstall,包括其功能、使用方法及注意事项,旨在帮助用户更好地理解和应用这一工具。 ... [详细]
  • 本文深入探讨了服务器的主要作用,包括加速访问、增强安全性和绕过访问限制等,并详细介绍了如何正确配置代理服务器。 ... [详细]
  • 在使用Ant Design的Tabs组件时,遇到了动画抖动的问题。本文详细记录了从发现问题到最终解决的过程,包括尝试的各种方法和最终解决方案。 ... [详细]
author-avatar
永远的菜鸟
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有