网站LOGO
公爵书房 | 技术分享
页面加载中
10月4日
网站LOGO 公爵书房 | 技术分享
以指键之轻,承载知识之重
菜单
  • 公爵书房 | 技术分享
    以指键之轻,承载知识之重
    用户的头像
    首次访问
    上次留言
    累计留言
    我的等级
    我的角色
    打赏二维码
    打赏博主
    yaml语言学习笔记
    点击复制本页地址
    微信扫一扫
    文章二维码
    文章图片 文章标题
    创建时间
  • 一 言
    确认删除此评论么? 确认
  • 本弹窗介绍内容来自,本网站不对其中内容负责。

    yaml语言学习笔记

    公爵 · 原创 ·
    笔记 · 学习笔记yaml
    共 4345 字 · 约 3 分钟 · 15
    本文最后更新于2023年09月02日,已经过了31天没有更新,若内容或图片失效,请留言反馈

    简介

    YAML 是 "YAML Ain't a Markup Language"(YAML 不是一种标记语言)的递归缩写。在开发的这种语言时,YAML 的意思其实是:"Yet Another Markup Language"(仍是一种标记语言)。

    YAML 的语法和其他高级语言类似,并且可以简单表达清单、散列表,标量等数据形态。它使用空白符号缩进和大量依赖外观的特色,特别适合用来表达或编辑数据结构、各种配置文件、倾印调试内容、文件大纲(例如:许多电子邮件标题格式和YAML非常接近)。

    YAML 的配置文件后缀为 .yml,如:runoob.yml

    yaml常用来用作配置文件,和json类似

    基本语法

    • 大小写敏感
    • 使用缩进表示层级关系
    • 缩进不允许使用tab,只允许空格
    • 缩进的空格数不重要,只要相同层级的元素左对齐即可
    • '#'表示注释

    数据类型

    YAML 支持以下几种数据类型:

    • 对象:键值对的集合,又称为映射(mapping)/ 哈希(hashes) / 字典(dictionary)
    • 数组:一组按次序排列的值,又称为序列(sequence) / 列表(list)
    • 纯量(scalars):单个的、不可再分的值

    YAML 对象

    对象的几种表示形式:

    1、对象键值对使用冒号结构表示 key: value,冒号后面要加一个空格。

    text 代码:
    key: value

    2、也可以使用 key:{key1: value1, key2: value2, ...}

    text 代码:
    key:{child-key1:value1,child-key2:value2}

    3、还可以使用缩进表示层级关系;

    text 代码:
    key: 
        child-key1: value1
        child-key2: value2

    同2,只是表示形式不同。

    4、较为复杂的对象格式,可以使用问号加一个空格代表一个复杂的 key,配合一个冒号加一个空格代表一个 value:

    text 代码:
    ?  
        - complexkey1
        - complexkey2
    :
        - complexvalue1
        - complexvalue2

    意思即对象的属性是一个数组 [complexkey1,complexkey2],对应的值也是一个数组 [complexvalue1,complexvalue2]

    YAML 数组

    - 开头的行表示构成一个数组:

    text 代码:
    - A
    - B
    - C

    YAML 支持多维数组,可以使用行内表示:

    text 代码:
    key: [value1, value2, ...]

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

    text 代码:
    -
     - A
     - B
     - C

    一个相对复杂的例子:

    text 代码:
    companies:
        -
            id: 1
            name: company1
            price: 200W
        -
            id: 2
            name: company2
            price: 500W

    意思是 companies 属性是一个数组,每一个数组元素又是由 id、name、price 三个属性构成。

    数组也可以使用流式(flow)的方式表示:

    text 代码:
    companies: [{id: 1,name: company1,price: 200W},{id: 2,name: company2,price: 500W}]

    复合结构(对象和数组组合)

    数组和对象可以构成复合结构,例:

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

    转换为 js 为:

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

    纯量

    纯量是最基本的,不可再分的值,包括:

    • 字符串
    • 布尔值
    • 整数
    • 浮点数
    • Null
    • 时间
    • 日期

    使用一个例子来快速了解纯量的基本使用:

    text 代码:
    boolean: # 布尔值
        - TRUE  #true,True都可以
        - FALSE  #false,False都可以
    float: # 浮点数
        - 3.14
        - 6.8523015e+5  #可以使用科学计数法
    int: # 整数
        - 123
        - 0b1010_0111_0100_1010_1110    #二进制表示
    null: # Null
        nodeName: 'node'
        parent: ~  #使用~表示null
    string: # 字符串
        - 哈哈 # 字符串默认不使用引号表示
        - 'Hello world'  #可以使用双引号或者单引号包裹特殊字符
        - newline
          newline2    #字符串可以拆成多行,每一行会被转化成一个空格
    date:
        - 2018-02-17    #日期必须使用ISO 8601格式,即yyyy-MM-dd
    datetime: 
        -  2018-02-17T15:02:31+08:00    #时间使用ISO 8601格式,时间和日期之间使用T连接,最后使用+代表时区

    多行字符串可以使用保留换行符,也可以使用>折叠换行。

    text 代码:
    this: 
      Foo
      Bar
    that: >
      Foo
      Bar

    转为js代码如下。

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

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

    text 代码:
    s1: 
      Foo
     
    s2: +
      Foo
     
     
    s3: -
      Foo

    转为json代码如下

    text 代码:
    { s1: 'Foo\n', s2: 'Foo\n\n\n', s3: 'Foo' }

    字符串之中可以插入 HTML 标记。

    text 代码:
    message: 
      <p style="color: red">
        段落
      </p>

    转换数据格式

    允许使用两个感叹号,强制转换数据类型。

    text 代码:
    e: !!str 123
    f: !!str true

    转换js结果同:

    text 代码:
    { e: '123', f: 'true' }

    锚点引用

    & 锚点和< span class="marked">* 别名,可以用来引用:

    text 代码:
    defaults: &defaults # 添加锚点
      adapter:  postgres
      host:     localhost
    
    development:
      database: myapp_development
      <<: *defaults # <<表示合并,*引用锚点
    
    test:
      database: myapp_test
      <<: *defaults # <<表示合并,*引用锚点

    相当于:

    text 代码:
    defaults:
      adapter:  postgres
      host:     localhost
    
    development:
      database: myapp_development
      adapter:  postgres
      host:     localhost
    
    test:
      database: myapp_test
      adapter:  postgres
      host:     localhost

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

    下面是另一个例子:

    text 代码:
    - &showell Steve 
    - Clark 
    - Brian 
    - Oren 
    - *showell 

    转为js代码如下:

    text 代码:
    [ 'Steve', 'Clark', 'Brian', 'Oren', 'Steve' ]

    参考文档

    yaml官网

    yaml与js的转换demo

    菜鸟教程

    声明:本文由 公爵(博主)原创,依据 CC-BY-NC-SA 4.0 许可协议 授权,转载请注明出处。

    还没有人喜爱这篇文章呢

    发一条! 发一条!
    博客logo 公爵书房 | 技术分享 以指键之轻,承载知识之重 51统计 百度统计
    MOEICP 萌ICP备20226257号 ICP 赣ICP备2022001242号-1 ICP 闽公网安备35020502000606号 又拍云 本站由又拍云提供CDN加速/云存储服务

    🕛

    本站已运行 1 年 257 天 6 小时 31 分

    🌳

    自豪地使用 Typecho 建站,并搭配 MyLife 主题
    公爵书房 | 技术分享. © 2022 ~ 2023.
    网站logo

    公爵书房 | 技术分享 以指键之轻,承载知识之重
     
     
     
     
    壁纸