Skip to main content

Vinyl

虚拟的文件格式。当 src() 读取文件时,将生成一个 Vinyl 对象来表示文件——包括路径、内容和其他元数据。

Vinyl 对象可以使用插件进行转换。还可以使用 dest() 将它们持久化到文件系统。

当创建您自己的 Vinyl 对象时——而不是使用 src() 生成——使用外部 vinyl 模块,如下面的用法所示。

用法

const Vinyl = require('vinyl');

const file = new Vinyl({
cwd: '/',
base: '/test/',
path: '/test/file.js',
contents: new Buffer('var x = 123')
});

file.relative === 'file.js';

file.dirname === '/test';
file.dirname = '/specs';
file.path === '/specs/file.js';

file.basename === 'file.js';
file.basename = 'file.txt';
file.path === '/specs/file.txt';

file.stem === 'file';
file.stem = 'foo';
file.path === '/specs/foo.txt';
file.extname === '.txt';
file.extname = '.js';
file.path === '/specs/foo.js';

函数原型

new Vinyl([options])

参数

参数类型描述
optionsobject详情请参加下文 选项

返回值

返回一个 Vinyl 类的实例,表示一个单独的虚拟文件,详见下面的 Vinyl 实例

可能出现的错误

当传递的任何选项都不符合表中定义的实例属性定义(如 path 被设置为一个数字)时抛出错误。

选项

名称类型默认住
cwdstringprocess.cwd()此目录用于推导相对路径。该目录路径将被 规范化(normalized) 并删除结尾的目录分隔符。
basestring用于计算 relative 实例属性。 如果没有设置,则回退到 cwd 的值。通常设置为 glob base。该路径将被 规范化(normalized) 并删除结尾的目录分隔符。
pathstring完整的绝对文件路径。该路径将被 规范化(normalized) 并删除结尾的目录分隔符。
historyarray[ ]此路径数组用于预先填充 Vinyl 实例的 history 属性。通常是从先前的 Vinyl 对象衍生处新的 Vinyl 对象。通过同时传递了 pathhistory 参数,则将path 附加到 history 后面。数组中的每个条目都将被 规范化(normalized) 并删除结尾的目录分隔符。
statobject一个 fs.Stats 实例,通常是对文件调用 fs.stat() 的结果。用于确定 Vinyl 对象是否表示一个目录或符号链接。
contentsReadableStream
Buffer
null
null文件的内容。如果 contents 是一个 ReadableStream,它将被包装进一个 cloneable-readable 流(stream
)中。

options 上的任何其他属性都将直接分配给 Vinyl 实例。

const Vinyl = require('vinyl');

const file = new Vinyl({ foo: 'bar' });
file.foo === 'bar';

Vinyl 实例

每个 Vinyl 对象实例都具有访问和/或修改虚拟文件信息的属性和方法。

实例属性

所有内部管理的路径——除了 contentsstat 之外的任何实例属性——都被规范化,并删除了末尾分隔符。有关更多信息,请参见规范化和连接

属性类型描述抛出错误
contentsReadableStream
Buffer
null
获取和设置虚拟文件的内容。如果将其设置为 ReadableStream,它将被包装在一个 cloneable-readable 流(stream)中。如果设置为 ReadableStream、Buffer 或 null 之外的任何值。
statobject获取或设置 fs.Stats 的实例。当确定 Vinyl 对象是否表示目录或符号链接时使用。
cwdstring获取并设置当前工作目录。用于推导相对路径。如果设置为空字符串或任何非字符串值。
basestring获取和设置起始目录(base directory)。用于计算实例的 relative 属性。在由 src() 生成的 Vinyl 对象上,将设置为 glob base。如果设置为 nullundefined,则会用实例属性 cwd 的值来代替。如果设置为空字符串或任何非字符串值(nullundefined 除外)。
pathstring获取和设置完整的绝对文件路径。设置为与当前 path 不同的值会将新路径附加到 history 实例属性中。如果设置为任何非字符串值。
historyarray已分配的 Vinyl 对象的所有 path 值的数组。第一个元素是原始路径,最后一个元素是当前路径。此属性及其包含元素应被视为只读,仅通过设置 path 实例属性间接更改。
relativestring获取 basepath 实例属性之间的相对路径段。如果设置为任何值。如果在 path 不可用时访问。
dirnamestring获取和设置 path 实例属性的目录。如果在 path 不可用时访问。
stemstring获取和设置 path 实例属性的不带扩展名的文件名。如果在 path 不可用时访问。
extnamestring获取和设置 path 实例属性的扩展名。如果在 path 不可用时访问。
basenamestring获取和设置 path 实例属性的文件名(stem + extname)。如果在 path 不可用时访问。
symlinkstring获取和设置符号链接的引用路径。如果设置为任何非字符串值。

实例方法

方法返回值类型返回值
isBuffer()boolean如果 contents 实例属性是一个 Buffer,则返回 true。
isStream()boolean如果 contents 实例属性是一个 Stream,则返回 true。
isNull()boolean如果 contents 实例属性为 null,则返回 true。
isDirectory()boolean如果实例表示一个目录,则返回 true。当 isNull() 返回 true,stat 实例属性是一个对象,并且 stat.isDirectory() 返回 true 时,实例被认为是一个目录。这假设 Vinyl 对象是用一个有效的(或适当模拟的) fs.Stats 对象构造的。
isSymbolic()boolean如果实例表示符号链接,则返回 true。 当 isNull() 返回 true,stat 实例属性是一个对象,并且 stat.isSymbolicLink() 返回 true 时, 实例被认为是 symbolic。 这假设 Vinyl 对象是用一个有效的(或适当模拟的) fs.Stats 对象构造的。
clone([options])objectA new Vinyl object with all properties cloned. 一个使用所有属性克隆出的新的 Vinyl 对象。 默认情况下,自定义属性是深拷贝。如果 deep 选项为 false,自定义属性将被浅拷贝。如果 contents 选项设置为 fasle 并且 contents 属性是一个 Buffer,那么这个 Buffer 将被复用,而不是克隆。
inspect()string返回 Vinyl 对象的格式化说明。由 Node 的 console.log 自动调用。

路径规范化和连接

所有路径属性都由它们的 setter 进行规范化。使用 / 连接路径,而不是使用 path.join(),这样就可以在所有平台上正确地进行规范化。永远不要使用 \ 连接。( \ 是 POSIX 系统上的一个有效文件名字符。)

const file = new File();
file.path = '/' + 'test' + '/' + 'foo.bar';

console.log(file.path);
// posix => /test/foo.bar
// win32 => \\test\\foo.bar