Vue.js学习的第一天

Vue.js学习的第一天官网文档地址:传送门一、Vue介绍:1.Vue.js是什么?作者:2014年2月,尤雨溪曾就职于GoogleCreativeLabs和MeteorDevelopmentGroup。Vue(读音/vjuː/,类似于view)是一套用于构建用户界面的渐进式框架。与其它大型框架不同的是,Vue被设计为可以自底向上逐层应用。Vue的核心库只关注视图层,不仅易于上手,还便于与第三方库或既有项目整合。另一方面,当与现代化的工具链以及各种支持类库结合使用时,Vu..

大家好,又见面了,我是你们的朋友全栈君。

Vue.js学习的第一天

官网文档地址:传送门

一、Vue介绍:

1.Vue.js是什么?

  • 作者:2014年2月,尤雨溪曾就职于Google Creative Labs和Meteor Development Group。
  • Vue (读音 /vjuː/,类似于 view) 是一套用于构建用户界面的渐进式框架。与其它大型框架不同的是,Vue 被设计为可以自底向上逐层应用。Vue 的核心库只关注视图层,不仅易于上手,还便于与第三方库或既有项目整合。另一方面,当与现代化的工具链以及各种支持类库结合使用时,Vue 也完全能够为复杂的单页应用提供驱动

2.Vue的特点:

  • 简单:在HTML,CSS,JavaScript基础上扩展。
  • 易用:渐进式框架,逐层应用,有丰富的第三方库。
  • 轻量:开发版大小约为300K,生产版大小约为30K。

3.Vue的功能:

  • 解耦视图和数据
  • 可重复的组件
  • 数据绑定
  • 功能插件化
  • 虚拟DOM

4.相比于Angular.js、React.js、为何Vue.js要技高一筹?

  • Angular.jsGoogle公司推出,Java后端程序员开发,将java的MVC模式复刻到前端,在前端设计增加了模块发开发概念
  • React.js:Facebook公式推出,提出了虚拟DOM概念,在内存中模拟DOM操作,提升了前端的渲染效率。
  • Vue.js:渐进式框架,综合了Angular.js的特点(模块化开发)和React(虚拟DOM)的优点。相对于Vue.js、Angular.js、React.js后两者学习成本较高。Vue.js基于MVVM设计模式,有着轻量级、数据绑定、响应式和组件化开发等特点。

二、MVC和MVVM设计模式:

1.MVC设计模式:

MVC设计模式基本思想就将项目层次分解为Model(模型层)、View(视图层)、Controller(控制层)。

  • Model层:主要负责数据处理和运算
  • View层:主要负责显示数据和用户交互
  • Controller层:主要负责业务接受数据并控制视图层的跳转

2.MVVM设计模式

MVVM设计模式由Model(模型)、View(视图)、ViewModel(视图模型)三部分组成。是MVC模式的进阶版。

MVVM设计模式和MVC模式一样,主要的目的是分离视图(View)和模型(Model),主要有以4个优点:

  • 低耦合:View可以独立于Model的变化和修改,一个VIew Model可以绑定到不同的View上,当View变化时Model可以不变化,当Model变化时View也可以不用变化。

  • 独立开发:开发人员更加专注于业务逻辑和数据的开发(ViewModel),设计人员可以专注于界面的设计。

  • 可重复性:可以把一些视图逻辑放在一个ViewModel中,让更多的View重用这段视图逻辑。

  • 可测试:现在测试人员可以针对ViewMdoel来写。

三、 构建Vue开发环境

方式一:用CND的方式搭建Vue.js开发环境:

  • <! – 引入CDN开发版 –>
<script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
  • <! – 引入CDN生产版 –>
<script src="https://cdn.jsdelivr.net/npm/vue"></script>

方式二:下载官网Vue.js文件,相对位置引入到项目中

<script src="../XXX/vue.js"></script>

方式三: node .js命令行搭建Vue

在项目文件夹下使用DOS命令

npm install vue

四、你好,Vue

我的第一个Vue项目

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>我的第一个Vue项目</title>
</head>
<body>
    <div class="app">  
        <!-- 动态传值写法 { 
   { 
   }} -->
        { 
   { 
   message}}
    </div>
    <!-- 引入CDN开发版 -->
    <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
    <script>
        var app = new Vue({ 
   
            el: '.app', //选择要传值的标签 
            data: { 
   
                message: 'Hello Vue!'//给标签内传值
            }
        })
    </script>
</body>
</html>
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/127182.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 数学速算法_小学数学速算技巧全收录,寒假全面提升!

    数学速算法_小学数学速算技巧全收录,寒假全面提升!小编说:关注“学习方法报”免费获取更多学习干货,助你快速提分。想订阅报纸的各位童鞋请点击底部菜单——“微商城”查询答案的各位童鞋请点击底部菜单——“答案查询”——“小学答案”很多同学反映,自己的数学计算能力弱,每次数学考试,很多时间都花费在了计算上面,希望我能帮助他解决这个问题。所以今天我们就来和大家分享小学数学中的实用的速算技巧,同学们只要掌握了这个方法,计算问题一定会有一个大的提高!…

    2022年6月29日
    46
  • php 全部替换字符串,php如何批量替换字符串

    php 全部替换字符串,php如何批量替换字符串php如何批量替换字符串2020-10-0614:54:06php批量替换字符串的方法:使用【str_replace】批量查找替换字符串,代码为【$str=str_replace(‘o’,’O’,$str,$count);echo$str.PHP_EOL;】。php批量替换字符串的方法:str_replace批量查找替换字符串…

    2022年5月10日
    45
  • ssdp java_SSDP协议 – 实施[通俗易懂]

    ssdp java_SSDP协议 – 实施[通俗易懂]我正在尝试实现SSDP协议,但我不确定它是如何工作的.SSDP通过udp发送数据,这很清楚.如果控制器连接到网络,它可以搜索具有MSEARCH消息的设备,该消息可以发送到多播地址239.255.255.250:1900.每个设备都必须收听此地址并做出响应.但我不知道他们是如何回应的.我在wireshark中看到他们用单播响应,但我不知道如何确定接收响应的端口.编辑–…

    2022年10月11日
    4
  • hdu 4891—水的问题 但WA非常多

    hdu 4891—水的问题 但WA非常多

    2022年1月17日
    39
  • 关于JavaScript闭包理解

    关于JavaScript闭包理解js 的作用域分两种 和 基于所熟悉的作用域链相关知识 知道在 js 作用域环境中访问变量的权利是的 内部作用域可以获得当前作用域下的变量并且可以获得当前包含当前作用域的外层作用域下的变量 反之则不能 也就是说在外层作用域下无法获取内层作用域下的变量 同样在不同的函数作用域中也是不能相互访问彼此变量的 那么想在一个函数内部也有限权访问另一个函数内部的变量该怎么办呢 闭包就是用来解决这一需求的 我们首先知道闭包有 3 个特性 函数嵌套函数 函数内部可以引用函数外部的参数和变量 参数和变量不会被垃圾回收机制回

    2025年9月16日
    4
  • 修改host访问github_github下载单个文件

    修改host访问github_github下载单个文件修改host文件登录github

    2022年10月11日
    4

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号