GoFrame 配置管理-YAML格式

2022-03-29 15:24 更新

一、簡(jiǎn)介

?YAML? 語言(發(fā)音 /?j?m?l/ )的設(shè)計(jì)目標(biāo),就是方便人類讀寫。它實(shí)質(zhì)上是一種通用的數(shù)據(jù)串行化格式。

它的基本語法規(guī)則如下。

  • 大小寫敏感
  • 使用縮進(jìn)表示層級(jí)關(guān)系
  • 縮進(jìn)時(shí)不允許使用?Tab?鍵,只允許使用空格。
  • 縮進(jìn)的空格數(shù)目不重要,只要相同層級(jí)的元素左側(cè)對(duì)齊即可

?#? 表示注釋,從這個(gè)字符一直到行尾,都會(huì)被解析器忽略。

?YAML ?支持的數(shù)據(jù)結(jié)構(gòu)有三種。

  • 對(duì)象:鍵值對(duì)的集合,又稱為映射(?mapping?)/ 哈希(?hashes?) / 字典(?dictionary?)
  • 數(shù)組:一組按次序排列的值,又稱為序列(?sequence?) / 列表(?list?)
  • 純量(?scalars?):?jiǎn)蝹€(gè)的、不可再分的值

以下分別介紹這三種數(shù)據(jù)結(jié)構(gòu)。

二、對(duì)象

對(duì)象的一組鍵值對(duì),使用冒號(hào)結(jié)構(gòu)表示。

animal: pets

轉(zhuǎn)為JavaScript如下。

{ animal: 'pets' }

?Yaml也允許另一種寫法,將所有鍵值對(duì)寫成一個(gè)行內(nèi)對(duì)象。

hash: { name: Steve, foo: bar } 

轉(zhuǎn)為JavaScript如下。

{ hash: { name: 'Steve', foo: 'bar' } }

三、數(shù)組

一組連詞線開頭的行,構(gòu)成一個(gè)數(shù)組。

- Cat
- Dog
- Goldfish

轉(zhuǎn)為JavaScript如下。

[ 'Cat', 'Dog', 'Goldfish' ]

數(shù)據(jù)結(jié)構(gòu)的子成員是一個(gè)數(shù)組,則可以在該項(xiàng)下面縮進(jìn)一個(gè)空格。

-
 - Cat
 - Dog
 - Goldfish

轉(zhuǎn)為JavaScript如下。

[ [ 'Cat', 'Dog', 'Goldfish' ] ]

數(shù)組也可以采用行內(nèi)表示法。

animal: [Cat, Dog]

轉(zhuǎn)為JavaScript如下。

{ animal: [ 'Cat', 'Dog' ] }

四、復(fù)合結(jié)構(gòu)

對(duì)象和數(shù)組可以結(jié)合使用,形成復(fù)合結(jié)構(gòu)。

languages:
 - Ruby
 - Perl
 - Python 
websites:
 YAML: yaml.org 
 Ruby: ruby-lang.org 
 Python: python.org 
 Perl: use.perl.org 

轉(zhuǎn)為JavaScript如下。

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

五、純量

純量是最基本的、不可再分的值。以下數(shù)據(jù)類型都屬于JavaScript的純量。

  • 字符串
  • 布爾值
  • 整數(shù)
  • 浮點(diǎn)數(shù)
  • Null
  • 時(shí)間
  • 日期

數(shù)值直接以字面量的形式表示。

number: 12.30

轉(zhuǎn)為JavaScript如下。

{ number: 12.30 }

布爾值用?true?和?false?表示。

isSet: true

轉(zhuǎn)為?JavaScript如下。

{ isSet: true }

?null?用?~?表示。

parent: ~ 

轉(zhuǎn)為JavaScript如下。

{ parent: null }

時(shí)間采用 ?ISO8601格式。

iso8601: 2001-12-14t21:59:43.10-05:00 

轉(zhuǎn)為JavaScript如下。

{ iso8601: new Date('2001-12-14t21:59:43.10-05:00') }

日期采用復(fù)合iso8601格式的年、月、日表示。

date: 1976-07-31

轉(zhuǎn)為JavaScript如下。

{ date: new Date('1976-07-31') }

?YAML允許使用兩個(gè)感嘆號(hào),強(qiáng)制轉(zhuǎn)換數(shù)據(jù)類型。

e: !!str 123
f: !!str true

轉(zhuǎn)為JavaScript如下。

{ e: '123', f: 'true' }

六、字符串

字符串是最常見,也是最復(fù)雜的一種數(shù)據(jù)類型。

字符串默認(rèn)不使用引號(hào)表示。

str: 這是一行字符串

轉(zhuǎn)為?JavaScript?如下。

{ str: '這是一行字符串' }

如果字符串之中包含空格或特殊字符,需要放在引號(hào)之中。

str: '內(nèi)容: 字符串'

轉(zhuǎn)為?JavaScript如下。

{ str: '內(nèi)容: 字符串' }

單引號(hào)和雙引號(hào)都可以使用,雙引號(hào)不會(huì)對(duì)特殊字符轉(zhuǎn)義。

s1: '內(nèi)容\n字符串'
s2: "內(nèi)容\n字符串"

轉(zhuǎn)為JavaScript如下。

{ s1: '內(nèi)容\\n字符串', s2: '內(nèi)容\n字符串' }

單引號(hào)之中如果還有單引號(hào),必須連續(xù)使用兩個(gè)單引號(hào)轉(zhuǎn)義。

str: 'labor''s day' 

轉(zhuǎn)為JavaScript如下。

{ str: 'labor\'s day' }

字符串可以寫成多行,從第二行開始,必須有一個(gè)單空格縮進(jìn)。換行符會(huì)被轉(zhuǎn)為空格。

str: 這是一段
  多行
  字符串

轉(zhuǎn)為JavaScript如下。

{ str: '這是一段 多行 字符串' }

多行字符串可以使用?|?保留換行符,也可以使用?>?折疊換行。

this: |
  Foo
  Bar
that: >
  Foo
  Bar

轉(zhuǎn)為JavaScript代碼如下。

{ this: 'Foo\nBar\n', that: 'Foo Bar\n' }

?+?表示保留文字塊末尾的換行,?-?表示刪除字符串末尾的換行。

s1: |
  Foo

s2: |+
  Foo


s3: |-
  Foo

轉(zhuǎn)為JavaScript代碼如下。

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

字符串之中可以插入HTML標(biāo)記。

message: |

  <p style="color: red">
    段落
  </p>

轉(zhuǎn)為JavaScript如下。

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

七、引用

錨點(diǎn)?&?和別名?*?,可以用來引用。

defaults: &defaults
  adapter:  postgres
  host:     localhost

development:
  database: myapp_development
  <<: *defaults

test:
  database: myapp_test
  <<: *defaults

等同于下面的代碼。


defaults:
  adapter:  postgres
  host:     localhost

development:
  database: myapp_development
  adapter:  postgres
  host:     localhost

test:
  database: myapp_test
  adapter:  postgres
  host:     localhost

?&?用來建立錨點(diǎn)(?defaults?),?<<?表示合并到當(dāng)前數(shù)據(jù),?*?用來引用錨點(diǎn)。

下面是另一個(gè)例子。

- &showell Steve 
- Clark 
- Brian 
- Oren 
- *showell 

轉(zhuǎn)為JavaScript代碼如下。

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


以上內(nèi)容是否對(duì)您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號(hào)
微信公眾號(hào)

編程獅公眾號(hào)