欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

.NET Core实战项目之CMS 第六章 入门篇-Vue的快速入门及其使用

程序员文章站 2022-03-12 14:55:07
写在前面 上面文章我给大家介绍了Dapper这个ORM框架的简单使用,大伙会用了嘛!本来今天这篇文章是要讲Vue的快速入门的,原因是想在后面的文章中使用Vue进行这个CMS系统的后台管理界面的实现。但是奈何Vue实现的SPA有一定的门槛,不太适合新手朋友,所以为了照顾大多数人,我准备还是采用asp. ......

写在前面

上面文章我给大家介绍了dapper这个orm框架的简单使用,大伙会用了嘛!本来今天这篇文章是要讲vue的快速入门的,原因是想在后面的文章中使用vue进行这个cms系统的后台管理界面的实现。但是奈何vue实现的spa有一定的门槛,不太适合新手朋友,所以为了照顾大多数人,我准备还是采用asp.net core mvc+html+js+css+layui这个传统的技术栈来实现。但是,不管怎么说我还是会把vue的基本使用给大伙介绍一下!
当然,如果这篇文章我也是抱着学习的态度跟大家一起来了解vue的,如果你想通过这篇文章就能熟练的使用vue那你就太天真了!目前,作为后端的我对vue的掌握也仅仅停留在入门阶段。后期再带着大家一起把这个项目升级到vue吧!

本篇文章已经收纳入《.net core实战项目之cms 第一章 入门篇-开篇及总体规划》另附上.net core实战项目交流群:637326624 有兴趣的朋友可以共同交流技术经验。
作者:依乐祝
原文地址:https://www.cnblogs.com/yilezhu/p/10035275.html

vue是什么

vue (读音 /vjuː/,类似于 view) 是一套用于构建用户界面的渐进式框架。与其它大型框架不同的是,vue 被设计为可以自底向上逐层应用。vue 的核心库只关注视图层,不仅易于上手,还便于与第三方库或既有项目整合。另一方面,当与现代化的工具链以及各种支持类库结合使用时,vue 也完全能够为复杂的单页应用提供驱动。
说白了vue.js就是当下很火的一个javascript mvvm库(前端库)。相比于angular.js,vue.js提供了更加简洁、更易于理解的api,使得我们能够快速地上手并使用vue.js。
如果你之前已经习惯了用jquery操作dom,学习vue.js时请先抛开手动操作dom的思维,因为vue.js是数据驱动的,你无需手动操作dom。它通过一些特殊的html语法,将dom和数据绑定起来。一旦你创建了绑定,dom将和数据保持同步,每当变更了数据,dom也会相应地更新。
当然了,在使用vue.js时,你也可以结合其他库一起使用,比如jquery。

vue.js的特点

  • 简洁: html 模板 + json 数据,再创建一个 vue 实例,就这么简单。

  • 数据驱动: 自动追踪依赖的模板表达式和计算属性。

  • 组件化: 用解耦、可复用的组件来构造界面。

  • 轻量: 生产版本删除了警告后共30.90kb min+gzip,无依赖(2.5.17版本)。

  • 快速: 精确有效的异步批量 dom 更新。

  • 模块友好: 通过 npm 或 bower 安装,无缝融入你的工作流。

如何学习vue.js

这里介绍几个比较好的vue学习的网站,都是免费的!大伙可以跟着系统的学习下。毕竟我最开始也是看了下面的官方教程以及菜鸟教程里面的vue教程的。
vue的官方中文教程:https://cn.vuejs.org/v2/guide/index.html
vue.js菜鸟教程:http://www.runoob.com/vue2/vue-tutorial.html
github地址:https://github.com/vuejs/vue
releases地址:https://github.com/vuejs/vue/releases

快速开始运行vue.js

vue的安装

这里需要注意的是vue 不支持 ie8 及以下版本,因为 vue 使用了 ie8 无法模拟的 ecmascript 5 特性。但它支持所有兼容 ecmascript 5 的浏览器。目前最新稳定版本是:2.5.17。目前就两种我认为常用的安装方式罗列如下:至于npm以及cli的方式我就不推荐了,专业的前端玩的东西我感觉高大上,懒得折腾。

  1. 直接下载并用 标签引入(像平时引入js一样引入即可),vue 会被注册为一个全局变量。

    在开发环境下不要使用压缩版本,不然你就失去了所有常见错误相关的警告!

    开发版本:https://vuejs.org/js/vue.js 包含完整的警告和调试模式

    生产版本:https://vuejs.org/js/vue.min.js 删除了警告,30.90kb min+gzip

  2. cdn 方式直接引入csn地址即可

    官方推荐链接到一个你可以手动更新的指定版本号:

    <script src="https://cdn.jsdelivr.net/npm/vue@2.5.17/dist/vue.js"></script>
    

    你可以在 浏览 npm 包的源代码。

    vue 也可以在 和 上获取 (cdnjs 的版本更新可能略滞后)。

    请确认了解不同构建版本并在你发布的站点中使用生产环境版本,把 vue.js 换成 vue.min.js。这是一个更小的构建,可以带来比开发环境下更快的速度体验。

vue.js输出一个hello world

程序员界万年不变的定理,开始一门语言就从hello world开始。下面就让我们快速开始用vue.js输出一个“hello world!”吧

  1. 新建一个html文件,不要跟我说你不知道怎么创建一个html文件,不然你会被“达丝蒂”。这里我们用visual studio code来进行代码的编写。

    .NET Core实战项目之CMS 第六章 入门篇-Vue的快速入门及其使用

  2. 打开上面新建的helloworld.html文件,并输入如下的内容:

    
    

    然后在浏览器中打开这个html文件看到如下的结果:.NET Core实战项目之CMS 第六章 入门篇-Vue的快速入门及其使用

    我们已经成功创建了第一个 vue 应用!看起来这跟渲染一个字符串模板非常类似,但是 vue 在背后做了大量工作。现在数据和 dom 已经被建立了关联,所有东西都是响应式的。我们要怎么确认呢?打开你的浏览器的 javascript 控制台 (就在这个页面打开),并修改 app.__vue__.message 的值并按回车,你将看到上例相应地更新。

    .NET Core实战项目之CMS 第六章 入门篇-Vue的快速入门及其使用

vue.js常用的指令

vue.js的指令是以v-开头的,它们作用于html元素,指令提供了一些特殊的特性,将指令绑定在元素上时,指令会为绑定的目标元素添加一些特殊的行为,我们可以将指令看作特殊的html特性(attribute)。
接下来我们就给大家分别来介绍一下vue中比较常用的指令

v-mode

在vue.js中可以使用v-model指令,它能轻松实现表单输入和应用状态之间的双向绑定。
为了演示这个效果,我们新建一个sample02.html的文件,然后输入如下的代码:

<!doctype html>
<html>
  <head>
  <meta charset="utf-8">
  <title>hello world</title>
  <!-- 开发环境版本,包含了有帮助的命令行警告 -->
  <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
  </head>
  <body>
    <div id="app">
      <p>{{ message }}</p>
      <input v-model="message">
    </div>

    <script>
      new vue({
        el: '#app',
        data: {
          message: 'hello world!'
        }
      })
    </script>
  </body>
</html>

可以看到文本框的内容发生变化后,对应的文本框上面的文本也发生了变化,这里没有截成动态图,大家可以自行测试。
.NET Core实战项目之CMS 第六章 入门篇-Vue的快速入门及其使用

v-if ,v-else,v-else-if

条件判断指令,大家看着是不是觉得很熟悉呢,简直就跟c#中的if, else if,else 一毛一样啊(当然又有些区别,不过用法一样)下面我们给出要一个实例代码来进行演示
,这里我们新建要给sample03.html的文件,然后输入如下的代码:

<!doctype html>
<html>
  <head>
  <meta charset="utf-8">
  <title>hello world</title>
  <!-- 开发环境版本,包含了有帮助的命令行警告 -->
  <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
  </head>
  <body>
    <div id="app">
      <p>{{ score }}</p>
      <input v-model="score">
      <div v-if="score>=90">
        优秀
      </div>
      <div v-else-if="score>=80&&score<90">
        优
      </div>
      <div v-else-if="score>=70&&score<80">
        良
      </div>
      <div v-else-if="score>=60&&score<70">
        及格
      </div>
      <div v-else>
        不及格
      </div>
    </div>

    <script>
      new vue({
        el: '#app',
        data: {
            score: 100
        }
      })
    </script>
  </body>
</html>

在浏览器中打开看到如下的界面,因为初始值我们设置的是100

.NET Core实战项目之CMS 第六章 入门篇-Vue的快速入门及其使用

当你在输入框中改变值的时候,对应的文本框上面及下面的值都会发生变化,大伙可以自己试一下。.NET Core实战项目之CMS 第六章 入门篇-Vue的快速入门及其使用

v-show

v-show也是条件渲染指令,和v-if指令不同的是,使用v-show指令的元素始终会被渲染到html,它只是简单地为元素设置css的style属性。
下面我们创建一个sample04.html的文件,然后输入如下的代码进行测试:

<!doctype html>
<html>
  <head>
  <meta charset="utf-8">
  <title>hello world</title>
  <!-- 开发环境版本,包含了有帮助的命令行警告 -->
  <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
  </head>
  <body>
    <div id="app">
      <p v-show="score<60">成绩为:{{ score }}不及格了!</p>
      <p v-show="score>=60">成绩为:{{ score }}及格了!</p>
      <input v-model="score">
    </div>

    <script>
      new vue({
        el: '#app',
        data: {
          score: 50
        }
      })
    </script>
  </body>
</html>

然后在浏览器中看到如下的结果

.NET Core实战项目之CMS 第六章 入门篇-Vue的快速入门及其使用

这时候我们查看一下源文件,可以看到下面的那个多了一些style="display:none" 的样式。但是html代码还是被渲染出来了

.NET Core实战项目之CMS 第六章 入门篇-Vue的快速入门及其使用

v-for

循环使用 v-for 指令。
v-for 指令需要以 site in sites 形式的特殊语法, sites 是源数据数组并且 site 是数组元素迭代的别名。
v-for 可以绑定数据到数组来渲染一个列表
下面我们创建一个sample05.html的文件,然后输入如下的代码进行测试:

<!doctype html>
<html>
  <head>
  <meta charset="utf-8">
  <title>hello world</title>
  <!-- 开发环境版本,包含了有帮助的命令行警告 -->
  <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
  </head>
  <body>
    <div id="app">
        <h2>解决问题途径</h2>
        <ol>
            <li v-for="method in methods">
                {{ method.name }}
            </li>
        </ol>
    </div>

    <script>
        new vue({
            el: '#app',
            data: {
                methods: [
                    { name: '谷歌' },
                    { name: '必应' },
                    { name: '百度' },
                    { name: '群里问别人'}
                ]
            }
        })
    </script>
  </body>
</html>

然后再浏览器中打开,看到如下的结果:

.NET Core实战项目之CMS 第六章 入门篇-Vue的快速入门及其使用

v-bind

v-bind指令可以在其名称后面带一个参数,中间放一个冒号隔开,这个参数通常是html元素的特性(attribute),如:<div v-bind:class="{ active: isactive }"></div>
我们新建一个sample06.html的文件,然后输入如下的代码

<!doctype html>
<html>
  <head>
  <meta charset="utf-8">
  <title>hello world</title>
  <!-- 开发环境版本,包含了有帮助的命令行警告 -->
  <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
  <style>
        .active {
            font-size: 20px;
            color: red;
        }
        </style>
  </head>
  <body>
    <div id="app">
      <p v-bind:class="{active:isactive}">{{ message }}</p>
      <input v-model="message">
    </div>

    <script>
      new vue({
        el: '#app',
        data: {
          message: 'hello world!',
          isactive: true
        }
      })
    </script>
  </body>
</html>

再浏览器中打开可以看到如下的结果

.NET Core实战项目之CMS 第六章 入门篇-Vue的快速入门及其使用

v-bind指令可以缩写为一个冒号 ,<div :class="{ active: isactive }"></div>

v-on

v-on指令用于监听dom事件,它的用语法和v-bind是类似的,例如监听button元素的点击事件:
<button v-on:click="dosomething">

下面我们简单的进行下代码的演示,老规矩,新建一个sample07.html文件,然后输入如下的代码:

<!doctype html>
<html>
  <head>
  <meta charset="utf-8">
  <title>hello world</title>
  <!-- 开发环境版本,包含了有帮助的命令行警告 -->
  <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
  <style>
        .active {
            font-size: 20px;
            color: red;
        }
    </style>
  </head>
  <body>
    <div id="app">
      <p class="active">您点击了{{counter}}次!</p>
      <button v-on:click="addcounter">快点我看效果吧!</button>
    </div>

    <script>
      new vue({
        el: '#app',
        data: {
            counter:0
        },
        methods:{
            addcounter:function(){
                this.counter++;
            }
        }
      })
    </script>
  </body>
</html>

然后在浏览器中打开,并点击按钮按下效果吧

.NET Core实战项目之CMS 第六章 入门篇-Vue的快速入门及其使用

注:v-on指令可以缩写为@符号,如:<button @click="addcounter">快点我看效果吧!</button>

总结

今天带着大家学习了一下vue.js这个前端框架。首先通过一个hello world的实例开始,然后给大家介绍了vue.js中常用的一些指令,并且每个指令都给出了一个实例代码,大伙可以自己跑一下看下效果。当然这也仅仅是vue的基础,像涉及比较深的组件,路由,动画等等内容没有过多的讲解。主要还是让大家快速的了解一下vue。同时为了照顾更多的朋友。有兴趣的朋友可以加下我们的.net core实战项目交流群637326624,跟大伙进行交流。好了,到这里.net core实战项目之cms的入门篇就结束了。接下来我们就将进入设计篇的内容了!大家准备好了嘛?