YAML学习

一:什么是YAML?
YAML是专门用来写配置文件的语言,通过它来编写完成后,我们可以通过插件JS-YAML(https://github.com/nodeca/js-yaml)来转换成我们的json数据。

二:有如下基本语法规则:

1 大小写敏感
2 使用缩进表示层级关系
3 缩进时相同层级的元素左侧对齐即可
4 使用 "#" 来表示注释。

支持的数据格式如下:

1. 对象:键值对的集合。
2. 数组:
3. 纯量;单个的,不可再分的值

2.1 对象
对象是由一组键值对组成,是使用冒号结构来表示;如下:

name: kongzhi

它会被转为如下的json数据:

{ name: 'kongzhi' }

假如我现在的项目目录如下结构:

### 目录结构如下:
demo # 工程名
| |--- index.js
| |--- index.yaml
| |--- package.json

index.yaml 代码如下:
name: kongzhi

index.js 代码如下:

const yaml = require('js-yaml');
const fs = require('fs'); const doc = yaml.safeLoad(fs.readFileSync('./index.yaml', 'utf-8')); console.log(doc);

执行命令 node index.js 就可以打印出
{ name: 'kongzhi' }

YAML也允许如下写法,将所有键值对写成一个行内对象;如下:

obj: { name: kongzhi, age: 30 }

转为js就变成如下:
{ obj: { name: 'kongzhi', age: 30 } }

2.2 数组:
一组以横线开头的行,构成一个数组。 如下代码:

- kongzhi
- longen
- tugenhua

转为js变为如下:
[ 'kongzhi', 'longen', 'tugenhua' ]

嵌套数组:

对数组可以嵌套数组,比如 [['kongzhi', 'longen', 'tugenhua']] 这样的。可以如下代码:

-
- kongzhi
- longen
- tugenhua

对象嵌套数组:

比如如下代码:

obj:
- kongzhi
- longen
- tugenhua

就会转为为成:

{ obj: [ 'kongzhi', 'longen', 'tugenhua' ] }

这样的。

数组也可以嵌套对象, 比如如下这样的:

-
{ name: kongzhi, age: 30 }

-
name: kongzhi
age: 30

转为js,变为如下:
[ { name: 'kongzhi', age: 30 } ]

如果多个数组的话,如下这种写法是可以的;
[
  { name: kongzhi, age: 30 },
  { name: kongzhi, age: 30 }
]

或者如下这样的:

- name: kongzhi
- name: longen0707
- name: tugenhua

就会转化成如下这样的:

[
{ name: 'kongzhi' },
{ name: 'longen0707' },
{ name: 'tugenhua' }
]

2.3 纯量
纯量是最基本的,不可再分的值,以下数据类型都属于javascript的纯量。

字符串,布尔型,整数,浮点数,Null, 时间, 日期等

1. 字符串

字符串默认不使用引号表示。如下:
str: 空智

转为js变为如下:
{ str: '空智' }

但是如果字符串中包含空格或特殊字符需要使用引号;如下所示:
str: '空智: 123'

转为js变为如下:
{ str: '空智: 123' }

如果不使用引号就会报错的

单引号中如果还有单引号,需要使用单引号进行转义,比如:
name: I am Tom's

需要写成如下:
name: 'I am Tom''s'

最后会转成 如下这样的:
{ name: 'I am Tom\'s' }

字符串也可以写成多行,从第二行开始,必须有一个单空格缩进,换行符会转换为空格。如下:

name: 这是一段
多行
字符串

转换成js变为如下:

{ name: '这是一段 多行 字符串' }

保留换行符 和 折叠换行

多行字符串可以使用 | 保留换行符,使用 > 折叠换行;如下代码:

name: |
kongzhi
longen0707
age: >
kongzhi
longen0707

转为js变为如下:

{ name: 'kongzhi\nlongen0707\n', age: 'kongzhi longen0707\n' }

+ 表示保留文字块末尾的换行,- 表示删除字符串末尾的换行

如下代码:

name1: |
kongzhi name2: |+
longen0707 name3: |-
tugenhua

转为js变为如下:

{
name1: 'kongzhi\n',
name2: 'longen0707\n\n\n\n',
name3: 'tugenhua'
}

字符串中插入HTML标记

如下代码:

name: |
<div style="color:blue">
xxx
</div>

转为js变为如下:

{ name: '<div style="color:blue">\n  xxx\n</div>\n' }

2. 布尔型:
布尔值是使用true和false表示;如下代码:
isFlag: false

转换成js变为如下:

{ isFlag: false }

其中 null 使用 ~ 表示; 如下代码:
obj: ~
转为js变为如下:

{ obj: null }

3. 引用
锚点 & 和 别名 *, 可以用来引用,& 是用来建立锚点,<< 表示合并到当前数据,* 是用来引用锚点。 如下代码:

objects: &objects
name: kongzhi
age: 30 object2:
name: longen0707
<<: *objects object3:
name: tugenhua
<<: *objects

转换为js变为如下:

{
objects: { name: 'kongzhi', age: 30 },
object2: { name: 'longen0707', age: 30 },
object3: { name: 'tugenhua', age: 30 }
}

详情demo 请看 http://nodeca.github.io/js-yaml/

YAML学习的更多相关文章

  1. 【Yaml】Yaml学习笔记

    转载:https://blog.csdn.net/moshenglv/article/details/52084899 YAML何许物也?在XML泛滥的情况下,YAML的出现的确让人眼前一亮,在初步学 ...

  2. 更适合Pythoner的标记语言Yaml学习总结

    pythonic的标记语言 之前总结过一篇关于小数据存储文件大比拼,当时着重介绍了json,因为它在各类编程语言的通用性较强.但今天,我想给大家介绍一款更加适合pythoner使用的语言Yaml. Y ...

  3. Python Yaml 学习

    最近开始使用Python3.x,所有今后无特殊说明,Python代表的就是Python3.x 最近在看代码时发现有人用Yaml —— Yet Another Markup Language :另一种标 ...

  4. Yaml学习文档

    pdf文档地址 http://yaml.org/spec/ JS-Yaml demo地址 http://nodeca.github.io/js-yaml/

  5. Yaml学习笔录

    YAML概要 [YAML](http://yaml.org/)是"YAML Ain't a Markup Language"(YAML不是一种置标语言)的递归缩写,早先YAML的意 ...

  6. 通过一篇YAML来学习YAML

    yaml 兼容 json,至今已发展至 1.2版.支持N多种编程语言.官网:http://www.yaml.org/ 格式在线校验:http://nodeca.github.io/js-yaml/ 下 ...

  7. ansible-playbook的YAML语法学习

    YAML:可以将你打算对多机器的批量操作放到一个文件中,顺序执行,可以根据机器做到根据机器信息判断执行,其他命令执行结果判断执行. YAML有着严格的层级要求,稍微有个缩进问题就会无法运行,所以学习过 ...

  8. Python Selenium Cookie 绕过验证码实现登录

    Python Selenium Cookie 绕过验证码实现登录 之前介绍过博客园的通过cookie 绕过验证码实现登录的方法.这里并不多余,会增加分析和另外一种方法实现登录. 1.思路介绍 1.1. ...

  9. [k8s]一些技巧性的yaml和dockerfile-docker学习思路

    我会把一些dockerfile和yaml的技巧性东西不定期搜集到这里 docker学习思路 三部曲: 1,vm会搭建服务 2,docker会跑服务 3,k8s集群会调度该服务 存储 vm1 vm2 共 ...

随机推荐

  1. vue项目未加载完成前显示loading...

    1.在Index.html里面加入loading的元素,让loading元素显示,让app元素隐藏 <!DOCTYPE html> <html> <head> &l ...

  2. Csharp: read Sybase SQL anywhere5.5 using c#

    private void button1_Click(object sender, EventArgs e) { try { //OdbcConnection conn = new OdbcConne ...

  3. jquery弹窗时禁止body滚动条滚动

    当弹出一个jq提示窗口的时候,一般窗口右边还会有进度条的情况,禁止进度条方法禁止浏览器滚动条滚动: $('body').css({ "overflow-x":"hidde ...

  4. 2018-01-04 浅尝The Little Prover一书, 重逢Chez Scheme

    书开篇之前说, 本书的目标的一个例子: 证明(reverse (reverse x))对于任何列表x, 结果总是x. (安装Chez Scheme的200字请看最后) 书刚开始, 就用到一个schem ...

  5. 从零开始学习html(二)认识标签(第一部分)——下

    八.<blockquote>标签,长文本引用 <!DOCTYPE HTML> <html> <head> <meta http-equiv=&qu ...

  6. [Android GMS 认证] keystore/keymaster/Attestation的问题

    首先确定写入key,操作如下: 检查 /persist/data/sfs 目录下是否有key文件存在     adb shell ls -la /persist/data/sfs 做过key prov ...

  7. Django 知识总结(一)

    Django已经学过的知识点: 1. Urls.py 路由系统: 正则 分组匹配 --> 位置参数 分组命名匹配 --> 关键字参数 分级路由 include 给路由起别名 name=&q ...

  8. 根据学习廖雪峰老师的git教程做的笔记

    根据学习廖雪峰老师的git教程做的笔记 安装git 进行git的配置 配置您的用户名和邮箱地址,使用--global 这个参数表明了在此台机器上的所有仓库都会使用该配置 $ git config -- ...

  9. windows server 2008额外域控提升为主域控

    windows server 2008额外域控提升为主域控 ---图形界面操作方法 https://blog.csdn.net/tladagio/article/details/79618338 wi ...

  10. 计算机硬件基本知识及Linux的常用命令

    ------------------1. 计算机硬件基本知识------------------ CPU - 寄存器 - L1/L2/L3 - 内存 - 硬盘 - 互联网下载/其他存储介质传输 寄存器 ...