yaml 语言 语法 规则

yaml 语言

语法规则:
1.大小写敏感
2.使用缩进表示 层级关系
3.缩进时不允许使用 tab键,只允许使用空格
4缩进的空格数目不重要,只要相同层级的元素左侧对齐即可

yaml 支持的数据结构有三种
1.对象:键值对的集合,又称为映射 mapping 哈希 hashes 字典 dictionary
2.数组 一组按次序排列的值,又称为序列 sequence 列表 list
3.纯量 scalars 单个的 不可再分的值

二 对象
对象的一组键值对,使用 冒号结构表示
animal:pets
转为JavaScript 如下
{animal: 'pets'}

yaml 也允许另一种写法,将所有键值对写成一个行内对象
hash: {name:steve,foo:bar}

转为JavaScript 如下
{hash:{name:'Steve',foo:'bar'}}

三 数组
一组连词线 开头的行,构成一个数组

-cat
-Dog
-Goldfish

转为 JavaScript 如下
['cat','Dog','Goldfish']

数组结构的子成员 是一个数组,则可以在该项下面缩进一个空格

    • Cat
    • Dog
    • Goldfish

转为 JavaScript如下
[['cat' ,'Dog','Goldfish']]

数组也可以采用行内表示法
animal: [cat,Dog]
转为JavaScript如下
{animal:['cat','Dog']}

四 复合结构

对象和数组可以结合使用,形成复合结构
languages:
- ruby
- perl
- python
websites:
YAML : yaml.org
Ruby : ruby-lang.org
Python : python.org
Perl : use.perl.org

转为 javascript :
{ languages:['ruby','perl','python'],

websites:
{ YAML : 'yaml.org',
  Ruby: 'ruby-lang.org',
  Python: 'python.org',
  Perl: 'use.perl.org'

}}

五 纯量
纯量是最基本的,不可再分的值,一下数据类型都属于 JavaScript 的纯量
1.字符串
2.布尔值
3.整数
4.浮点数
5.Null
6.时间
7.日期

数值直接以字面量的形式表示
number:12.30
转为JavaScript如下
{number:12.30}

布尔值用 true 和false 表示
isSet :true

转为JavaScript
{isSet:true}

null 用 ~ 表示
parent:~

转为JavaScript 如下
{parents:null}

时间采用 ISO8601 格式
iso8601:2001-12-14t21:59:43.10-05:00

转为JavaScript 如下
{iso8601:new Date('2001-12-14t21:59:43.10-05:00')}

日期采用复合 iso8601 格式的年 、月 、日表示

date:1976-07-31
转为 JavaScript如下
{date : new Date('1976-07-31')}

yaml 允许 使用 两个感叹号,强制转换数据类型
e :!!str 123
f: !!str true

转为JavaScript 如下
{e:'123',f:'true'}

六 字符串

字符串是最常见,也是最复杂的一种数据类型
字符串默认不使用引号表示
str: 这是一行字符串
转为 JavaScript如下
{str: '这是一行字符串'}

如果字符串之中包含空格或者特殊字符,需要放在引号之中
str: '内容: 字符串'

转为JavaScript 如下
{str: '内容: 字符串'}

单引号和双引号都可以使用,双引号不会对 特殊字符转义

s1: '内容\n字符串'
s2: "内容\n字符串"

转为JavaScript如下
{s1:'内容\n字符串',s2: '内容\n字符串'}

单引号之中如果还有单引号,必须连续使用两个单引号转义
str: 'labor''s day'
转为 JavaScript如下
{str: 'labor's day'}

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

str: 这是一段
多行
字符串

转为JavaScript如下
{str: '这是一段 多行 字符串'}
多行字符串可以使用 | 保留换行符,也可以使用 > 折叠换行

this: |
Foo
Bar
that: >
Foo
Bar

转为 JavaScript 代码 如下
{this:'Foo\nBar\n',that: 'Foo Bar\n'}

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

s1: |
Foo
s2: |+

s3:|-
Foo

转为JavaScript 代码如下

{s1:'Foo\n',s2:'Foo\n\n\n',s3:'Foo'}

字符串 之中可以插入html 标记
message: |
<p stype="color: red" >
段落
</p>

转为JavaScript
{message: '\n<p style="color:red">\n 段落\n</p>\n'}

七 引用
锚点 & 和别名 *,可以用来引用

defaults: &defaults

adapter: postgres
host:   localhost

development:
database:myapp_development
<<: *defaults

test:

database: myapp_test
<<: *defaults

等同于下面的代码

defaults:
adapter: postgres
host: localhost

development:
database: myappp_development
adapter: postgres
host: localhost

test:
database: myapp_test
adapter: postgres
host: localhost

& 用来 建立锚点 (defaults),<< 表示 合并到当前 数据, *用来引用 锚点

下面 是 另一个列子

  • &showell steve
  • Clark
  • Brian
  • Oren
  • *showell

转为 JavaScript 代码 如下

['steve','Clark','Brian','Oren','Steve']

八。 函数 和正则表达式 的转换

这是 js-yaml 库特有的功能,可以把函数和正则表达式 转为字符串

example.yml

fn:function () {return 1}
reg: /test/

解析 上面的yml文件的代码如下

var yaml=require('js-yaml')
var fs=require('fs')

try{
var doc =yaml.load(
fs.readFileSync('./example.yml','utf8')
)
console.log(doc)
}catch(e){
console.log(e)
}

从 JavaScript 对象还原 到yaml 文件的代码 如下

var yaml =require('js-yaml')
var fs = require('fs')

var obj={
fn: function(){return 1},
reg:/test/
};
try {
fs.writeFileSync(
'./example.yml',
yaml.dump(obj),
'utf8'
);
} catch(e){
console.log(e)
}

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,921评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,635评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,393评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,836评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,833评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,685评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,043评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,694评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 42,671评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,670评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,779评论 1 332
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,424评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,027评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,984评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,214评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,108评论 2 351
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,517评论 2 343

推荐阅读更多精彩内容