目录:

1、脚本式开发.

2、工程化开发

3、工程化和脚本的区别

4、来个table试试水

4,1、目标

4.2、思路

4.3、设计与编码

4.4、效果

5、业务分离

6、功能拓展——个性化设置

正文:

我以前是后端(asp.net)开发,会点js、jQuery,但是不会写js特效,至于css嘛,拿来用现成的可以,自己动手写就不会了。

发现现在前端开发的势头太猛了,有一点要干掉后端的感觉,于是萌发了想要学一学前端开发的想法。那么前端三大框架,先学哪一个呢?就先学学Vue吧,为啥呢?很简单呀,他只有三个英文字母,好记好写。

Vue的学习时间比较短,才三、五天吧,所以有些用法可能很稚嫩,甚至是错误的,不过不怕,才刚开始学,及时发现错误及时改正就好。每天都写点心得,万一遇见好人给指点一二,那就挣大发了。

Vue至少有两种开发方式:脚本是开发和工程化开发。

一、脚本式开发

就是和jQuery的使用有点像,在页面里引用vue.js,然后按照vue的规则写模板、写代码,就可以开鲁了。这种方式和jQuery挺像的,用着也是很爽的,改完代码一保存,浏览器里面一刷新就可以看到效果,很直观方便。

这种方式适合初初学者,以及对一些想法做测试,验证想法是否行的通。但是正式项目里面可不可以这么用呢?一本书里面说——不可以。但是作为一个Vue的初学者,我现在还没有能力做这个判断。

二、工程化开发

这个刚一开的时候感觉很懵逼,但是看着看着发现了,这个不就是后端做开发的方式吗?简直太像了。

后端开发,以asp.net mvc 为例(为啥不用其他语言呢?千万别挣,因为我只会这一种,其他的不会)。打开IDE,建立一个项目,选择框架版本,选择项目类型,选择。。。。。然后IDE会根据你的选择,加载DLL引用,加载必须的js脚本,建立文件夹,建立配置文件,建立默认页面、代码。然后一运行,一个简单的网站就出来了。

Vue的工程化开发居然也是这个样子的。首先要安装node和npm,然后安装Vue-cli,这个叫做脚手架,emmm,一脸懵逼这是啥?看看上一段我写的,这个脚手架统统能做。当然不是引用dll这类的,而是引用Vue开发需要的各种东东,也会让你做各种选择,最后建立文件夹,然后神奇的是,可以用node做一个站点,直接就运行了。还可以模拟后端。

这个也太牛叉了吧,我感觉,再加上一个数据库(比如mysql),就没有后端啥事了。

具体怎么做就不细说了,emmmm,好吧我现在也只是一知半解。反正很神奇就对了。

三、工程化和脚本的区别

如果说脚本开发,是把js文件引入到页面 ,然后写代码的话,那么工程化是把自己的代码加到了Vue的框架里面,给框架补点肉,整个项目就出来了。

历史的发展就是这样的,不管个人喜不喜欢,这种开发方式必定越来越火,不愿意接受的,早晚会被淘汰的。

四、来个table试试水

看官网、查百度会有一些简单的介绍,这里也是依据这些简单的介绍,来点稍微复杂一些的,也是比较实用的一种用法。因为我也只是初学,不知道这种用法属于什么级别的,抛砖引玉,拿出来供大家参考一下。

1、目标

不管做什么事情,都要先定一个目标,这里虽然只是一个试水,但是也应该知道要做成啥样子的。那么就定一个简单的表格吧,比如下图这个样子的。

很简单的一个表格,列不多,因为列数不是问题。看了实现方式你就知道了。

2、思路

Vue的特点就是——数据驱动视图。数据为主,然后把数据绑定到页面。这个是核心,千万别跑偏了。

那么我们来分析一下,这个表格由两个部分组成:表头和表体。

表头:公司名称、电话等。实际项目里肯定还会有很多列。这里先拿两个举例。使用

来标示。

表体:就是公司信息的列表,由多条数据组成,字段数量和表头对应。用

来标示。

那么我们设计一个表头和表体的数据包,然后让Vue一绑定就ok了。

3、设计与编码

先设计一个数据包,emmmm,不知道专业的叫法是啥,反正就是弄一个json的结构。比如这样

var table = new Vue({

el: '#table',

data: {

message: '公司信息!',

orderBy: ["c1", "c2"], //可以控制字段的先后顺序,想调整列的先后顺序,改这个数组就行,可以做个性化设置

tableTh: {//表头的描述信息

c1: {

title: "公司名称", //还可以增加其他描述,比如width等

align: "left"

},

c2: {

title: "电话",

align: "right"

}

},

dataList: [

{

//数据包,字段名作为关键字,便于列的调整先后顺序

c1: "度娘2",

c2: "123123123"

},

{

c1: "企鹅2",

c2: "7897899787"

},

{

c1: "阿里爸爸2",

c2: "456456456"

}

]

}

});

el 这个是Vue的保留字,必须这么写,后面是dom的ID,比如

。用jQuery的思路就是 $(‘#table')。

data 这个也是Vue的保留字,后面是model,结构可以随意设置,怎么玩就看想象力了。

当然Vue还有很多保留字,比如方法的等等,不过这里先介绍这两个,其他的以后再说。

然后在设计一个模板,比如这样:

{{ message }}

序号

{{th.title}}

{{index+1}}

{{td}}

不知道大家有没有发现一个问题:这里面没有任何和业务相关的东东,那个“序号”不算的话。

这个模板也很简单,表头用一个循环就出来了,数据包里面有多少列,就可以循环出来多少列,所以我开头说的,多少列不重要,因为循环就对了,管他多少列呢?

表体用了两个循环(嵌套循环)就出来了。这个用法比较很好理解吧。这个我就不想多解释了,说多了会有一种凑字数的感觉。

4、效果

发现我剧透了,上面那个图就是运行效果。数据包设计好,模板设置好,然后交给Vue就可以了,打开浏览器查看网页,就可以看到这个效果。

五、业务分离

这个模板可以看做是所有列表的通用模板,因为他适合任何一种数据,不管是公司信息列表,还是员工信息,还是产品信息,都可以这样写,而且copy过来之后不用改!因为我把业务相关的统统放到了数据包里面。增加一个列表需求,只需要写数据包即可,不用改模板代码,是不是很方便?

当然,如果大家都是这么做的,那么就是英雄所见略同。昨天在一个前端群里问了半天,也没有人告诉我,他们的数据列表是怎么做的,结果我到现在也还是不知道在Vue里面大家是怎么做数据列表的。百度了一下,也没发现啥有用的信息。

六、功能拓展个性化设置

不知道大家有没有遇到这样的情况,接到一个任务,要求做一个数据列表里面有n个字段,这个没啥的嘛,做呗。但是这么多的列哪个在前哪个在后呢?如果文档里明确说明了,那么好办,按照文档里的来呗。如果文档里没有明确说明先后顺序,那么咋办?只能按照自己的习惯来了。

然后做好之后给用户看,第一个领导看了说,这个电话怎么放这了,不重要放最后好了。

然后给另一个领导看说,哎,这个电话怎么放最后了,不是和你们说了吗,这个要放前面!

???刚才那个领导说,,,,,。

然后又给操作人员看,操作人说,这个电话放这里不习惯,能不能改一改?

这里只是举一个简单的例子,客户的需求总是千奇百怪的,调整顺序只是最简单最常见的。

对于客户来说,不就是改个位置吗,我用Excel天天改顺序,你们这个项目肯定比Excel厉害吧,改个顺序很难吗?

不难呀,只是别改来改去的,另外我到底听谁的?

细心的你可能会发现,数据包里面有一个orderBy: ["c1", "c2"]没有用上,这个是干嘛的?

这个不是给数据排序的,而是给列排序的。这个数组里放的是key,后面两个数据包都是以这些key来组织数据的。那么这个数组里的key的先后顺序就是列的先后顺序。

所以只需要改这个数组里的key就可以了。然后我们可以为每一个用户都设置一个独立的数组,这样每个用户都可以有自己的列的顺序了,互相不干扰。这样客户都满意了,我们也不用总是调整顺序了。

最后,模板需要改一下:

{{ message }}

序号

{{tableTh[key].title}}

{{i+1}}

{{tr[key]}}

先遍历这个数组,然后用里面的key提取数据在做绑定。这样,我们把调整列的先后顺序的业务需求也给分离出来了,还附带了一个福利——个性化设置。感谢大家的学习和对脚本之家的支持。

vue可填写表格_VUE写一个简单的表格实例相关推荐

  1. [Vue]如何实现一个简单的表格数据筛选查找 (根据ElementUI表格展示)(数组筛选)

    [Vue]如何实现一个简单的表格数据筛选查找 (根据ElementUI表格展示)(数组筛选) 能够解决的问题 在一个完整的数据数据渲染的 elementui 表格组件中,筛选输出数据 目录 布局代码 ...

  2. 用java写一个简单的区块链(下)

    用java写一个简单的区块链(下) 2018年03月29日 21:44:35 java派大星 阅读数:725 标签: 区块链java 更多 个人分类: 区块链 版权声明:本文为博主原创文章,转载请标明 ...

  3. 怎样写一个简单的操作系统?(原文标题:How to write a simple operating system) 分类: 翻译 2011-01-26 01:10 3175人阅读 评论(3) 收藏

    怎样写一个简单的操作系统?(原文标题:How to write a simple operating system) 分类: 翻译2011-01-26 01:10 3175人阅读 评论(3) 收藏 举 ...

  4. 写一个简单的Java界面程序

    写一个简单的Java界面程序 有时候未免想写一些有界面的java小程序练练手,那么如何写一个比较好看的界面话程序呢?下面小编就带你一步一步来搭建这个小洋房. 实现界面化编程要用到的一个主要包impor ...

  5. MQL5:写一个简单的自定义指标

    MQL5:写一个简单的自定义指标 在MT5平台中,交易者可根据自己的习惯.需要,去编写供自己参考的指标. 如何写一个简单的自定义的指标? 在这里将写一个 取当日最高价和最低价中值的折线 的指标 作为演 ...

  6. php设置一个日历,用PHP写一个简单的日历

    用PHP写一个简单的日历 作者:黑马 出处: 日历被广泛应用于网络日志.作为网络日志导航的一种实现方式,我们不需要太复杂的日历,有年.月.日.周日即可,本文要讨论的就是这类简单的日记. 一个日历在布局 ...

  7. 用python60行代码写一个简单的笔趣阁爬虫!三分一章?

    前言 利用python写一个简单的笔趣阁爬虫,根据输入的小说网址爬取整个小说并保存到txt文件.爬虫用到了BeautifulSoup库的select方法 结果如图所示: 本文只用于学习爬虫 一.网页解 ...

  8. 用java做一个简单记事本_用记事本写一个简单的java程序

    用记事本写一个简单的java程序 第一步: 安装好jdk,并设置好环境变量. 桌面-计算机(右键)-属性-高级系统设置-环境变量-path-在变量值后加上:和jdk安装路径加上(路径即为C:\Prog ...

  9. 动手写一个简单版的谷歌TPU

    https://www.toutiao.com/a6701092937394029064/ 谷歌TPU是一个设计良好的矩阵计算加速单元,可以很好的加速神经网络的计算.本系列文章将利用公开的TPU V1 ...

最新文章

  1. 思科路由器DHCP基础配置
  2. 如何选择合适的NoSQL数据库
  3. Linux下往移动硬盘拷贝数据步骤方式
  4. 信息系统项目管理师-信息化与信息系统核心知识点思维脑图
  5. python:数据库连接操作入门
  6. FPGA 状态机设计
  7. grep从文件末尾开始找_新人自学前端到什么程度才能找工作?
  8. CVE-2020-1472 域内提权利用(域提权)
  9. 用 TigerVNC 实现 Linux 远程桌面
  10. 用eslint + prettier + pre-commit管理项目(React)
  11. python __iter____next__
  12. sysvol共享没有出现的处理办法!
  13. java fx 重绘_如何重绘JAVA FX 2.2中的窗口(舞台)
  14. flume拦截器及自定义拦截器
  15. win10远程桌面Android软件,Android端Win10远程桌面更新:支持Windows虚拟桌面
  16. 工作占用了太多私人时间_当公司老板过多占用你的个人时间,虽然不是什么大事但很想辞职怎么办?...
  17. python逻辑型数据也叫布尔值_【python系统学习10】布尔值
  18. 老板让我通知领导们开会,有几个领导故意开会迟到,老板反而说我不会办事,怎么办?...
  19. 被误解的明朝——中国的文艺复兴(转)
  20. 网站域名服务器加密,网站实现全站https加密可以防止DNS劫持吗?

热门文章

  1. Conda/Virtualenv虚拟环境
  2. LinearLayer
  3. 如何寻找出微信官方的微信指数API ?
  4. Mac自己创建打开终端快捷键(任意软件)
  5. R语言相关性矩阵绘图
  6. 心电信号matlab处理,基于MATLAB的心电信号的数字滤波处理
  7. 刷脸支付不拿手机也能付款高大上
  8. 零跑股价受港股汽车概念股的大涨利好,零跑股价又有了信心
  9. 自动生成员工号c语言,C语言自定义数据类型
  10. 王者荣耀s22服务器维护,王者荣耀:S22赛季推迟开启,大量老玩家退游,只因官方的两次改动...