"中文编程"知乎专栏原链

为了检验中文命名在主流框架中的支持程度, 在vuejs官方入门教程第一部分的示例代码中尽量使用了中文命名. 所有演示都在本地测试通过, 源码在这里. 下面省略了很多原教程的说明内容, 而着重于代码示例本身. 欢迎问题/批评.

声明式渲染

  <div id="元素id">
<p>{{ 问候 }}</p>
</div>
var 应用1 = new Vue({
el: '#元素id',
data: {
问候: '吃了么?'
}
})

打开你的浏览器的控制台 (就在这个页面打开),并修改 应用1.问候,你将看到上例相应地更新。

  <div id="元素id2">
<span v-bind:title="动态绑定信息">
鼠标悬停几秒钟查看此处动态绑定的提示信息!
</span>
</div>
var 应用2 = new Vue({
el: '#元素id2',
data: {
动态绑定信息: '页面加载于 ' + new Date().toLocaleString()
}
})

再次打开浏览器的 JavaScript 控制台输入 应用2.动态绑定信息 = '新消息',就会再一次看到这个绑定了 title 属性的 HTML 已经进行了更新

条件与循环

  <div id="元素id3">
<p v-if="看得到">现在你看到我了</p>
</div>
var 应用3 = new Vue({
el: '#元素id3',
data: {
看得到: true
}
})

继续在控制台设置 应用3.看得到 = false,你会发现“现在你看到我了”消失了。

  <div id="元素id4">
<ol>
<li v-for="任务 in 任务表">
{{ 任务.内容 }}
</li>
</ol>
</div>
var 应用4 = new Vue({
el: '#元素id4',
data: {
任务表: [
{ 内容: '学习 JavaScript' },
{ 内容: '学习 Vue' },
{ 内容: '整个牛项目' }
]
}
})

警告如下, 但列表仍然显示. 已经在Vue项目新建issue

[Vue warn]: Error compiling template:

<div id="元素id4">
<ol>
<li v-for="任务 in 任务表">
{{ 任务.内容 }}
</li>
</ol>
</div> - invalid v-for alias "任务" in expression: v-for="任务 in 任务表" (found in <Root>)

在控制台里,输入 应用4.任务表.push({ 内容: '新项目' }),你会发现列表中添加了一个新项。

处理用户输入

v-on:click支持中文方法名, 但需要(). 为此在Vue项目新建issue, 经社区建议得知并检验, 另一种方式@click也支持中文命名, 同样需要().

  <div id="元素id5">
<p>{{ 问好 }}</p>
<button @click="倒着说()">@click有效</button>
<button v-on:click="倒着说()">v-on:click有效</button>
</div>
var 应用5 = new Vue({
el: '#元素id5',
data: {
问好: '你好'
},
methods: {
倒着说: function () {
this.问好 = this.问好.split('').reverse().join('')
}
}
})

表单输入和应用状态之间的双向绑定:

  <div id="元素id6">
<p>{{ 问好 }}</p>
<input v-model="问好">
</div>
var 应用6 = new Vue({
el: '#元素id6',
data: {
问好: '你好!'
}
})

组件化应用构建

  <div id="元素id7">
<ol>
<todo-item
v-for="物品 in 购物单"
v-bind:待购="物品"
v-bind:key="物品.序号">
</todo-item>
</ol>
</div>
Vue.component('todo-item', {
props: ['待购'],
template: '<li>{{ 待购.名称 }}</li>'
})
var 应用7 = new Vue({
el: '#元素id7',
data: {
购物单: [
{ 序号: 0, 名称: '蔬菜' },
{ 序号: 1, 名称: '肉' },
{ 序号: 2, 名称: '随便啥' }
]
}
})

这里的HTML标签todo-item和其他标签(如div, ol)一样, 不支持中文命名.

核心基本功能介绍结束.

后记

初步看来Vuejs对中文命名的支持不错, 尤其是模板的部分. 个别改进建议已经在Vue的github库以issue的方式提出, 社区的活跃度很高, 开发者对这些issue的反应很快, 标记上了”改进”标签, 并针对一个不支持中文命名的问题提供了解决方案.

感觉此类实践可以促进与其他开源社区的交流, 并推进框架的业务代码中对中文(Unicode)命名的支持程度.

11/20/2017 补记:

中文代码示例之Vuejs入门教程(一)问题后续

2017-11-09 中文代码示例之Vuejs入门教程(一)的更多相关文章

  1. 中文代码示例之Vuejs入门教程(一)

    原址: https://zhuanlan.zhihu.com/p/30917346 为了检验中文命名在主流框架中的支持程度, 在vuejs官方入门教程第一部分的示例代码中尽量使用了中文命名. 所有演示 ...

  2. 2017-11-20 中文代码示例之Vuejs入门教程(一)问题后续

    "中文编程"知乎专栏原文 第一个issue: Error compiling template if using unicode naming as v-for alias · I ...

  3. 中文代码示例之Angular入门教程尝试

    原址: https://zhuanlan.zhihu.com/p/30853705 原文: 中文代码示例教程之Angular尝试 为了检验中文命名在Angular中的支持程度, 把Angular官方入 ...

  4. 2017-11-07 中文代码示例之Angular入门教程尝试

    "中文编程"知乎专栏原址 原文: 中文代码示例教程之Angular尝试 为了检验中文命名在Angular中的支持程度, 把Angular官方入门教程的示例代码中尽量使用了中文命名. ...

  5. 2018-11-27 中文代码示例之Programming in Scala笔记第七八章

    续前文: 中文代码示例之Programming in Scala学习笔记第二三章 中文代码示例之Programming in Scala笔记第四五六章. 同样仅节选有意思的例程部分作演示之用. 源文档 ...

  6. 2018-12-09 疑似bug_中文代码示例之Programming in Scala笔记第九十章

    续前文: 中文代码示例之Programming in Scala笔记第七八章 源文档库: program-in-chinese/Programming_in_Scala_study_notes_zh ...

  7. 2018-11-16 中文代码示例之Programming in Scala笔记第四五六章

    续前文: 中文代码示例之Programming in Scala学习笔记第二三章. 同样仅节选有意思的例程部分作演示之用. 源文档仍在: program-in-chinese/Programming_ ...

  8. 中文代码示例之NW.js桌面应用开发初体验

    先看到了NW.js(应该是前身node-webkit的缩写? 觉得该起个更讲究的名字, 如果是NorthWest之意的话, logo(见下)里的指南针好像也没指着西北啊)和Electron的比较文章: ...

  9. 2018-08-11 中文代码示例之Spring Boot 2.0.3问好

    上次试用Spring Boot还是两年前: 中文代码示例之Spring Boot 1.3.3演示. 打算用在一个讨论组内小项目上, 于是从官网Building an Application with ...

随机推荐

  1. 怎么随时获取Spring的上下文ApplicaitonContext,和Spring管理的Bean

    BeanFactory接口 Interface BeanFactory getBean <T> T getBean(String name, Class<T> required ...

  2. linux scp 使用方法

    scp虽然只有把文见发送到远端和从远端copy文件俩功能,但是常常把俩功能的先写什么给计混了,所以我就用通俗的大白话给总结了下,十分容易记忆,这里给大家分享一下.scp 我们常用的两个功能: (1)把 ...

  3. 关于常用的编码工具如何引入jar包

    myeclipse和eclipse(差不多)引入jar包: 普通项目: 1.对准你的项目创建一个文件夹名字尽量命名成lib(注意要和src平级,不要在src下创建文件夹). 2.将下载好的依赖放到li ...

  4. Group By Grouping Sets

    Group by分组函数的自定义,与group by配合使用可更加灵活的对结果集进行分组,Grouping sets会对各个层级进行汇总,然后将各个层级的汇总值union all在一起,但却比单纯的g ...

  5. web前端异步数据交互(长连接)

    Workers异步任务 开始(注册): divobjx=document.getElementsByTagName("div")[0]; var workdong=new Work ...

  6. murri

    github: https://github.com/haltu/muuri 官网:https://haltu.github.io/muuri/   安装 npm install murri —sav ...

  7. 微信JSAPI支付回调

    在微信支付中,当用户支付成功后,微信会把相关支付结果和用户信息发送给商户,商户需要接收处理,并返回应答. 在经历了千幸万苦之,填完了所有的JSAPI支付的坑后(微信JSAPI支付 跟 所遇到的那些坑) ...

  8. python scrapy 爬取西刺代理ip(一基础篇)(ubuntu环境下) -赖大大

    第一步:环境搭建 1.python2 或 python3 2.用pip安装下载scrapy框架 具体就自行百度了,主要内容不是在这. 第二步:创建scrapy(简单介绍) 1.Creating a p ...

  9. 【原创+整理】简述何为调用约定,函数导出名以及extern C

    何为调用约定 调用约定指的是函数在调用时会按照不同规则,翻译成不同的汇编代码.这和参数的压栈顺序和栈的清理方式相关,也就是说不同的调用约定,这些方式会做相应改变.一般编译器是以默认的调用约定编译一份代 ...

  10. Go pprof性能监控

    Go net/http/pprof包提供了一个在WEB项目中使用的性能监控的工具, 使用时只需要引用包: _"net/http/pprof" 然后就可以在浏览器中访问地址: htt ...