陈鹏铭 93064e9f91 首次提交 пре 11 месеци
..
browser 93064e9f91 首次提交 пре 11 месеци
dist 93064e9f91 首次提交 пре 11 месеци
types 93064e9f91 首次提交 пре 11 месеци
LICENSE 93064e9f91 首次提交 пре 11 месеци
README.md 93064e9f91 首次提交 пре 11 месеци
index.d.ts 93064e9f91 首次提交 пре 11 месеци
index.js 93064e9f91 首次提交 пре 11 месеци
map.js 93064e9f91 首次提交 пре 11 месеци
package.json 93064e9f91 首次提交 пре 11 месеци
pair.js 93064e9f91 首次提交 пре 11 месеци
parse-cst.d.ts 93064e9f91 首次提交 пре 11 месеци
parse-cst.js 93064e9f91 首次提交 пре 11 месеци
scalar.js 93064e9f91 首次提交 пре 11 месеци
schema.js 93064e9f91 首次提交 пре 11 месеци
seq.js 93064e9f91 首次提交 пре 11 месеци
types.d.ts 93064e9f91 首次提交 пре 11 месеци
types.js 93064e9f91 首次提交 пре 11 месеци
types.mjs 93064e9f91 首次提交 пре 11 месеци
util.d.ts 93064e9f91 首次提交 пре 11 месеци
util.js 93064e9f91 首次提交 пре 11 месеци
util.mjs 93064e9f91 首次提交 пре 11 месеци

README.md

YAML

yaml is a JavaScript parser and stringifier for YAML, a human friendly data serialization standard. It supports both parsing and stringifying data using all versions of YAML, along with all common data schemas. As a particularly distinguishing feature, yaml fully supports reading and writing comments and blank lines in YAML documents.

The library is released under the ISC open source license, and the code is available on GitHub. It has no external dependencies and runs on Node.js 6 and later, and in browsers from IE 11 upwards.

For the purposes of versioning, any changes that break any of the endpoints or APIs documented here will be considered semver-major breaking changes. Undocumented library internals may change between minor versions, and previous APIs may be deprecated (but not removed).

For more information, see the project's documentation site: eemeli.org/yaml/v1

To install:

npm install yaml

Note: This is yaml@1. You may also be interested in the next version, currently available as yaml@next.

API Overview

The API provided by yaml has three layers, depending on how deep you need to go: Parse & Stringify, Documents, and the CST Parser. The first has the simplest API and "just works", the second gets you all the bells and whistles supported by the library along with a decent AST, and the third is the closest to YAML source, making it fast, raw, and crude.

import YAML from 'yaml'
// or
const YAML = require('yaml')

Parse & Stringify

YAML Documents

import { Pair, YAMLMap, YAMLSeq } from 'yaml/types'

CST Parser

import parseCST from 'yaml/parse-cst'

YAML.parse

# file.yml
YAML:
  - A human-readable data serialization language
  - https://en.wikipedia.org/wiki/YAML
yaml:
  - A complete JavaScript implementation
  - https://www.npmjs.com/package/yaml
import fs from 'fs'
import YAML from 'yaml'

YAML.parse('3.14159')
// 3.14159

YAML.parse('[ true, false, maybe, null ]\n')
// [ true, false, 'maybe', null ]

const file = fs.readFileSync('./file.yml', 'utf8')
YAML.parse(file)
// { YAML:
//   [ 'A human-readable data serialization language',
//     'https://en.wikipedia.org/wiki/YAML' ],
//   yaml:
//   [ 'A complete JavaScript implementation',
//     'https://www.npmjs.com/package/yaml' ] }

YAML.stringify

import YAML from 'yaml'

YAML.stringify(3.14159)
// '3.14159\n'

YAML.stringify([true, false, 'maybe', null])
// `- true
// - false
// - maybe
// - null
// `

YAML.stringify({ number: 3, plain: 'string', block: 'two\nlines\n' })
// `number: 3
// plain: string
// block: >
//   two
//
//   lines
// `

Browser testing provided by: