当前位置: 首页 > 编程日记 > 正文

为什么vue.js一眼看上去很美?

对其他框架我是佩服,对vue.js我则是爱。我就是一眼看上了vue.js,于是用它做各种东西,反反复复多次,然后觉得有些融会贯通,然后,我稍微细的思量了下,到底vue.js靓丽在哪?

还是上案例对比说明。这次的案例,UI看起来是:

clipboard.png

一个span,两个按钮,点击按钮会让span加1或者减1。它简单到你不需要分心关注,但是由足够说明典型的html场景——就是既有数据呈现也有按钮操作。

vanilla.js

首先出场的是vanilla.js(vanilla.js的意思是,不使用任何框架) ,代码是这样的:


<div id="app">
<p><span id="count">0</span><button id="inc">+</button><button id="dec">-</button></p>
</div>
<script>var counter = document.getElementById('count');var btn1 = document.getElementById('inc');var btn2 = document.getElementById('dec');var count = 0;btn1.addEventListener('click',function (){counter.innerHTML = ++count;})btn2.addEventListener('click',function (){counter.innerHTML = --count;})
</script>

代码行数倒是不算多,但是看起来的感受是:

  1. 使用了多个DOM API(getElementById,innerHTML)

  2. DOM API设计的复合词太长

我偏爱简洁的代码,而使用DOM API就构成了一种代码的臭味,让我喜欢不起来。

jquery

第二个出场的是jquery。我个人认为前端历史上来说,有几个标志性事件

  1. 微软加入了XMLHttpRequest。从此Ajax技术一发而不可收

  2. jquery。简单的Selector,精简的API,令世人只有有jquery,不知道有Vanilla.js

  3. Vue.js等相类似的框架。引入了数据绑定,以及组件技术到前端开发
    所有,jquery当然是排的上好的技术了。那么,使用jq,效果如何呢?

  <scriptsrc="https://code.jquery.com/jquery-3.1.1.js"integrity="sha256-16cdPddA6VdVInumRGo6IbivbERE8p7CQR3HzTBuELA="crossorigin="anonymous"></script>
<div id="app">
<p><span id="count">0</span><button id="inc">+</button> <button id="dec">-</button></p>
</div>
<script>
var count = 0 
$('#inc').click(function(){$("#count").html(++count)
})
$('#dec').click(function(){$("#count").html(--count)
})
</script>

分析一下:

  1. jquery的选择器比起原生的更好,即使和querySelector相比也更简洁

  2. 使用精简的API替代Vanilla的。比如.html()比起.getElementById()来说,是要看着舒服点的

然而,内核基本不变:依然是添加EventListener,命令式的取值和修改值,依然你得懂得DOM的节点选择、事件监听、回调函数等。

Vue.js

最后出场的是vue,代码是这样的:

<script src="https://unpkg.com/vue/dist/vue.js"></script>
<div id="app"><p>{{count}}<button @click="inc">+</button><button @click="dec">-</button></p>
</div>
<script>
new Vue({el:'#app',data () {return {count: 0}},methods: {inc () {this.count++},dec () {this.count--}}
})
</script>

第一感觉就是:

  1. 规整。数据(data),方法(methods)放置的工工整整,一目了然。它充分的利用js的字面量对象的语法

  2. 整个应用接口设计,基本上采用的都是简单。一眼看过去,一个复合词也没有(比如getElementById就是4个复合词)

好处是:

  1. 现在,你不需要挂接EventListener,使用@click语法自动绑定事件,使用{{}}自动绑定数据

  2. 你不需要DOM的一系列的知识就可以构造此程序;对初学者来说,这个门槛真是降低太多

Vue.js的优美和简约,来源于声明式编程的理念。就是说我不需要通过一系列的函数调用来完成一件事儿,而是直接声明想要什么事儿。比如:

  1. 程序员直接声明{{count}},告诉Vue,此处使用Vue实例中的data对象内的count属性来填充。而不是调用.getElementById,.textContent来设置。

  2. 程序员通过@click直接声明点击事件指向位置为Vue实例内对象methods对应的方法。而不是通过调用.addEventListener,传入回调函数的方式来实现事件监听

整个Vue.js的应用接口设计的非常优美,但是能量巨大,做到这一点需要很多功力。这就是我佩服的设计哲学。把麻烦留给自己,让开发者感受简洁。

作者:刘传君

创建过产品,创过业。好读书,求甚解。
可以通过 1000copy#gmail.com 联系到我

出品

bootstrap小书 https://www.gitbook.com/book/...
http小书 http://www.ituring.com.cn/boo...
Git小书 http://www.ituring.com.cn/boo...

相关文章:

阿里云MWC 2019发布7款产品:Blink每秒可完成17亿次计算

在巴塞罗那举行的MWC 2019上&#xff0c;国内厂商不仅展示了目前的5G发展进程&#xff0c;也带来了一些云计算方面的进展。据报道&#xff0c;阿里云面向全球发布了7款产品&#xff0c;涵盖无服务器计算、高性能存储、全球网络、企业级数据库、大数据计算等主要云产品&#xff…

运用面向对象原则,设计一款音乐点唱机

2019独角兽企业重金招聘Python工程师标准>>> &#xff0e;设计内容及要求 能够实现简单的音乐播放器功能&#xff0c;如&#xff1a;打开本地文件&#xff0c;播放&#xff0c;暂停&#xff0c;停止&#xff0c;背景播放&#xff0c;单曲循环等等&#xff0c;界面充…

多传感器融合之滤波(三)--------

多传感器融合之滤波&#xff08;三&#xff09;&#xff1a;IMU,GPS,Lidar,Ladar数据处理

【Codeforces】835B The number on the board (贪心)

把所有字符串上的数字加起来&#xff0c;看是否超过k&#xff0c;没有超过k的话&#xff0c;把字符串sort&#xff0c;从第一位开始&#xff0c;将字符变成9&#xff0c;直到sum大于等于k为止。 #include <iostream> #include <cstring> #include <string> …

拯救尴尬:鉴黄神器NSFW JS开源了!

近日&#xff0c;GitHub上开源了一款鉴定不雅内容的js库NSFW JS&#xff0c;你可以使用NSFW JS识别不雅内容&#xff0c;所有操作都只在客户端进行&#xff0c;甚至都不需要让文件离开用户的电脑。 演示地址&#xff1a;https://nsfwjs.com/ 项目地址&#xff1a;https://githu…

Linux下用于查看系统当前登录用户信息的4种方法

作为系统管理员&#xff0c;你可能经常会&#xff08;在某个时候&#xff09;需要查看系统中有哪些用户正在活动。有些时候&#xff0c;你甚至需要知道他&#xff08;她&#xff09;们正在做什么。本文为我们总结了4种查看系统用户信息&#xff08;通过编号&#xff08;ID&…

三维重建【一】——————(深度学习方式)

经典的计算机视觉问题是3-D重建。 基本上可以分成两种路径&#xff1a;一是多视角重建&#xff0c;二是运动重建。前者有一个经典的方法是多视角立体视觉&#xff08;MVS&#xff0c;multiple view stereo&#xff09;&#xff0c;就是多帧的立体匹配&#xff0c;这样采用CNN模…

【Codeforces】501B Misha and Changing Handles(map)

http://codeforces.com/problemset/problem/501/B map的应用&#xff0c;让新的名字作为key值&#xff0c;旧的名字作为value值&#xff0c;然后一一对应。如果这个旧名字不在map里&#xff0c;则添加进去&#xff1b;如果这个旧名字在map里&#xff0c;则需要进行替换&#x…

vue-cli3+typescript初体验

前言 气势汹涌&#xff0c;ts似乎已经在来的路上&#xff0c;随时可能敲门。2015年&#xff0c;三大前端框架开始火爆的时候&#xff0c;我还在抱着Backbone不放&#xff0c;一直觉得可以轻易转到其他框架去。后来换工作&#xff0c;现实把脸都打肿了&#xff0c;没做过vue、re…

三维重建【二】————3D reconstruction 较为实用的算法资料整理(传统方式)

本文结合一些pape并且将资源进行整合&#xff0c;以便于后期的学习。博客将这些资源一下&#xff0c;这里不得提到大名鼎鼎的KinectFusion以及他后面的一系列工作。KinectFusion单篇论文引用都已经超过3000次了&#xff0c;可以称得上是具有划时代意义的一篇巨著&#xff0c;如…

【Codeforces 738D】Sea Battle(贪心)

http://codeforces.com/contest/738/problem/D Galya is playing one-dimensional Sea Battle on a 1  n grid. In this game a ships are placed on the grid. Each of the ships consists of bconsecutive cells. No cell can be part of two ships, however, the ships ca…

【POJ】3617 Best Cow Line (字典序 字符串)

http://poj.org/problem?id3617 给定长度为N(1≤N≤2000)的字符串S&#xff0c;要构造一个长度为N的字符串T。期初&#xff0c;T是一个空串&#xff0c;随后反复进行下列任意操作。 从S的头部删除一个字符&#xff0c;加到T的尾部 从S的尾部删除一个字符&#xff0c;加到T的…

python数据池连接PG

发现网上都是mysql&#xff0c;后面发现PG跟mysql差不多&#xff0c;记录下来&#xff0c;怕忘了 import psycopg2 from DBUtils.PooledDB import PooledDB import psycopg2.extraspool PooledDB(psycopg2, 10,database"boatdb", user"postgres",password…

ASP.NET WebAPi之断点续传下载(下)

前言 上一篇我们穿插了C#的内容&#xff0c;本篇我们继续来讲讲webapi中断点续传的其他情况以及利用webclient来实现断点续传&#xff0c;至此关于webapi断点续传下载以及上传内容都已经全部完结&#xff0c;一直嚷嚷着把SQL Server和Oracle数据库再重新过一遍&#xff0c;这篇…

Git学习记录(一)

git-book 全面资料 git 用树形查看 &#xff08;git 命令代替gitk查看节点树part two 日常使用只要记住下图6个命令即可&#xff0c;但是学海无涯啊 ​ 常用 Git 命令清单。几个专用名词的译名如下。 Workspace&#xff1a;工作区Index / Stage&#xff1a;暂存区Reposito…

【牛客】CSL 的字符串 (stack map)

https://ac.nowcoder.com/acm/contest/551/D 这个题怎么说&#xff0c;data用来存储这个字母在字符串中最后一次出现的位置&#xff0c;vis则用来记录该字母是否在栈中。 当栈为空的时候&#xff0c;直接将s[i]放入栈中 如果不为空则需要比较栈顶元素和当前s[i]的那个元素&a…

Python:UTF-8编码转换成GBK编码

2019独角兽企业重金招聘Python工程师标准>>> #!/usr/bin/env python # -*- coding:utf-8 -*- #UTF-8转换成GBK编码 #temp #decode #encode #原理就是把UTF-8转换成万国码&#xff0c;再给万国码进行编码转换成GBK&#xff0c;在python 2.x里面这么用 ""&q…

三维重建【三】-------------------(三维重建资料收集)

Major学者的个人主页汇总&#xff1a; 1.陈宝权&#xff1a;http://web.siat.ac.cn/~baoquan/ 2.南亮亮&#xff1a;http://web.siat.ac.cn/~liangliang/ 3.mueller&#xff1a;http://people.ee.ethz.ch/~pascmu/publications.html 4.Yasutaka Furukawa:http://homes.cs.washi…

在 Linux 中查看时区

1.date date "%Z %z"或者 date -R2.timedatectl timedatectl|grep "Timezone"可以使用 timedatectl 来设置 Linux 时区 3.显示文件 /etc/timezone 的内容 cat /etc/timezone

【HDU】1237 简单计算器 (stack)

http://acm.hdu.edu.cn/showproblem.php?pid1237 题目很好理解&#xff0c;一开始想用优先队列&#xff0c;但好像有点难实现&#xff0c;用stack比较好实现&#xff0c;遇到“ * ” 或者" / " 就进行操作&#xff0c;遇到“ - ” 就把它的相反数加进stack&#xf…

关于 synchronizeOnSession

本文为[原创]文章&#xff0c;转载请标明出处。原文链接&#xff1a;https://weyunx.com/2019/01/22...原文出自微云的技术博客 最近在维护一个老项目&#xff0c;发现了一个问题。我们新增了一个耗时较久的复杂查询的功能&#xff0c;页面采用了 ajax 异步请求数据&#xff0c…

用python操作mysql数据库(之“更新”操作)

#!/usr/bin/env python # -*- coding: utf-8 -*-import MySQLdb#建立连接 conn MySQLdb.connect(host127.0.0.1,userroot,passwd1qaz#EDC,dbtest_db) cur conn.cursor()#对数据进行操作 sql "update user set name%s where id7" #定义sql语句&#xff0c;用于修改…

OpenCV【零】—————cv::Mat——Mat对象创建方法

OpenCV (一)——Mat对象创建方法 目录 OpenCV (一)——Mat对象创建方法 1. cv::Mat优点及原理&#xff08;本质类&#xff09; 2. Mat类拷贝及对象的创建方法 3. Mat 对象元素的高效访问 4. 存储方法 5. 显式创建Mat对象 6. 与其他语言对比的方式 7. Mat操作实例 1. c…

在Vmware中安装Ubuntu

转载自&#xff1a;https://blog.csdn.net/stpeace/article/details/78598333 不是每一个程序员都必须玩过linux&#xff0c;只是博主觉得现在的很多服务器都是linux系统的&#xff0c;而自己属于那种前端也搞&#xff0c;后台也搞&#xff0c;对框架搭建也感兴趣&#xff0c;…

C++回声服务器_5-多进程版本

服务器和客户端都是用多进程来接收和发送数据。 服务器代码 #include <cstdio> #include <cstdlib> #include <cstring> #include <unistd.h> #include <csignal> #include <sys/wait.h> #include <arpa/inet.h> #include <sys/s…

OpenCV 【一】—— OpenCV中数组指针、图像分块计算、指针取像素值与MatToEigen方法,内存对齐

{ Topic1: 高效开辟内存&#xff0c;使适用于大型数组。//开辟新数组&#xff0c;或者开辟新的0或者某一数值的数组/Mat或者Map直接使用memset //大数组操作效率较高 举例1&#xff1a;cv::Mat cv_ncc_temp(cv_input_32f.rows, cv_input_32f.cols, CV_8UC1);memset(cv_ncc_temp…

【Java】类与对象 - 参数传值

目录 面向过程语言简介 面向对象语言简介 面向对象编程的三个特性 参数传值 传值机制 基本数据类型的参数的传值 引用类型参数的传值 可变参数 面向过程语言简介 核心是编写解决问题某个问题的代码块&#xff0c;代码块是程序执行时产生的一种行为。面向过程语言缺少一…

新闻发布项目——业务逻辑层(newsTbService)

package bdqn.newsManageServlet.Service;import java.util.List;import bdqn.newsManageServlet.entity.newsTb;/*** 新闻业务逻辑层的接口* author Administrator**/ public interface newsTbService {//分页查询public List<newsTb>getPagingNews(int pagesize,int pa…

使用阿里云发布分布式网站,开发时候应该注意什么?

虽然之前写过关于负载均衡的文章&#xff0c;但是似乎大家都对负载均衡这个标题很陌生。今天就换个角度&#xff0c;从分布式网站发布角度说一下 首先&#xff0c;网站发布一定离不开服务器&#xff0c;就是阿里云的云服务器ECS。最近发现&#xff0c;老用户也有机会购买特价服…

【Java】类与对象 - 对象的组合

一个类的成员变量可以是Java允许的任何数据类型&#xff0c;因此&#xff0c;一个类可以把某个对象作为自己的成员变量&#xff0c;也就是说&#xff0c;该对象将其他对象作为自己的组成部分。 组合和复用 如果一个对象a组合了对象b&#xff0c;那么对象a就可以委托对象b调用…