接口声明
{"name": "system.file"}
导入模块
import file from '@system.file'
或
const file = require('@system.file')
接口定义
file.move(OBJECT)
将源文件移动到指定位置,接口中使用的URI描述请参考 文件组织
参数:
参数名 |
类型 |
必填 |
说明 |
srcUri |
String |
是 |
源文件的uri,不能是应用资源路径和tmp类型的uri |
dstUri |
String |
是 |
目标文件的uri,不能是应用资源路径和tmp类型的uri |
success |
Function |
否 |
成功回调,返回目标文件的uri |
fail |
Function |
否 |
失败回调 |
complete |
Function |
否 |
执行结束后的回调 |
fail返回错误代码:
错误码 |
说明 |
202 |
参数错误 |
300 |
I/O错误 |
示例:
file.move({
srcUri: 'internal://cache/path/to/file',
dstUri: 'internal://files/path/to/file',
success: function (uri) {
console.log(`move success: ${uri}`)
},
fail: function (data, code) {
console.log(`handling fail, code = ${code}`)
}
})
file.copy(OBJECT)
将源文件复制一份并存储到指定位置,接口中使用的URI描述请参考 文件组织
参数:
参数名 |
类型 |
必填 |
说明 |
srcUri |
String |
是 |
源文件的uri |
dstUri |
String |
是 |
目标文件的uri,不能是应用资源路径和tmp类型的uri |
success |
Function |
否 |
成功回调,返回目标文件的uri |
fail |
Function |
否 |
失败回调 |
complete |
Function |
否 |
执行结束后的回调 |
fail返回错误代码:
错误码 |
说明 |
202 |
参数错误 |
300 |
I/O错误 |
示例:
file.copy({
srcUri: 'internal://cache/path/to/file',
dstUri: 'internal://files/path/to/file',
success: function (uri) {
console.log(`copy success: ${uri}`)
},
fail: function (data, code) {
console.log(`handling fail, code = ${code}`)
}
})
file.list(OBJECT)
获取指定目录下的文件列表,接口中使用的URI描述请参考 文件组织
参数:
参数名 |
类型 |
必填 |
说明 |
uri |
String |
是 |
目录uri,不能是应用资源路径和tmp类型的uri |
success |
Function |
否 |
成功回调,返回{fileList:[{uri:'file1',lastModifiedTime:1234456, length:123456} ...]} |
fail |
Function |
否 |
失败回调 |
complete |
Function |
否 |
执行结束后的回调 |
success返回值:
参数名 |
类型 |
说明 |
fileList |
Array |
文件列表,每个文件的格式为{uri:'file1',lastModifiedTime:1234456, length:123456} |
每个文件的元信息:
参数名 |
类型 |
说明 |
uri |
String |
文件的 uri,该 uri 可以被其他组件或 Feature 访问 |
length |
Number |
文件大小,单位B |
lastModifiedTime |
Number |
文件的保存是的时间戳,从 1970/01/01 00:00:00 GMT 到当前时间的毫秒数 |
fail返回错误代码:
错误码 |
说明 |
202 |
参数错误 |
300 |
I/O错误 |
示例:
file.list({
uri: 'internal://files/movies/',
success: function (data) {
console.log(data.fileList)
},
fail: function (data, code) {
console.log(`handling fail, code = ${code}`)
}
})
file.get(OBJECT)
获取本地文件的文件信息,接口中使用的 URI 描述请参考 文件组织
参数:
参数名 | 类型 | 必填 | 说明 |
---|
uri | String | 是 | 文件的 uri,不能是应用资源路径 |
recursive 1060+ | Boolean | 否 | 是否递归获取子目录文件列表。默认false |
success | Function | 否 | 成功回调,返回 { uri:'file1', length:123456, lastModifiedTime:1233456 } |
fail | Function | 否 | 失败回调 |
complete | Function | 否 | 执行结束后的回调 |
success返回值:
参数名 | 类型 | 说明 |
---|
uri | String | 文件的 uri,该 uri 可以被其他组件或 Feature 访问 |
length | Number | 文件大小,单位 B |
lastModifiedTime | Number | 文件的保存是的时间戳,从 1970/01/01 08:00:00 到当前时间的毫秒数 |
type 1060+ | String | 文件类型,dir:目录;file:文件 |
subFiles 1060+ | Array | 文件列表,recursive为true且type为dir时递归返回子目录文件细信息,否则不返回 |
fail返回错误代码:
错误码 |
说明 |
202 |
参数错误 |
300 |
I/O 错误 |
示例:
file.get({
uri: 'internal://files/path/to/file',
success: function (data) {
console.log(data.uri);
console.log(data.length);
console.log(data.lastModifiedTime);
},
fail: function (data, code) {
console.log(`handling fail, code = ${code}`)
}
})
file.delete(OBJECT)
删除本地存储的文件,接口中使用的 URI 描述请参考 文件组织
参数:
参数名 |
类型 |
必填 |
说明 |
uri |
String |
是 |
需要删除的文件 uri,不能是应用资源路径和 tmp 类型的 uri |
success |
Function |
否 |
成功回调 |
fail |
Function |
否 |
失败回调 |
complete |
Function |
否 |
执行结束后的回调 |
fail返回错误代码:
错误码 |
说明 |
202 |
参数错误 |
300 |
I/O 错误 |
示例:
file.delete({
uri: 'internal://files/path/to/file',
success: function (data) {
console.log('handling success')
},
fail: function (data, code) {
console.log(`handling fail, code = ${code}`)
}
})
file.writeText(OBJECT)1010+
写文本到文件
参数:
参数名 | 类型 | 必填 | 说明 |
---|
uri | String | 是 | 本地文件路径,不支持资源文件路径和 tmp 分区,如果文件不存在会创建文件 |
text | String | 是 | 需要写入的字符串 |
encoding | String | 否 | 编码格式,默认 UTF-8 |
append 1060+ | Boolean | 否 | 是否追加模式,默认 false |
success | Function | 否 | 成功回调 |
fail | Function | 否 | 失败回调 |
complete | Function | 否 | 执行结束后的回调 |
fail返回错误代码:
错误码 |
说明 |
202 |
参数错误 |
300 |
I/O 错误 |
示例:
file.writeText({
uri: 'internal://files/work/demo.txt',
text: 'test',
success: function () {
console.log('handling success')
},
fail: function (data, code) {
console.log(`handling fail, code = ${code}`)
}
})
file.writeArrayBuffer(OBJECT)1010+
写Buffer到文件
参数:
参数名 | 类型 | 必填 | 说明 |
---|
uri | String | 是 | 本地文件路径,不支持资源文件路径和 tmp 分区,如果文件不存在会创建文件 |
buffer | Uint8Array | 是 | 需要写入的 Buffer |
position | Number | 否 | 指向文件开始写入数据的位置的偏移量,默认 0 |
append 1060+ | Boolean | 否 | 是否追加模式,默认 false。当为 true 时, position 参数无效 |
success | Function | 否 | 成功回调 |
fail | Function | 否 | 失败回调 |
complete | Function | 否 | 执行结束后的回调 |
fail返回错误代码:
错误码 |
说明 |
202 |
参数错误 |
300 |
I/O 错误 |
示例:
file.writeArrayBuffer({
uri: 'internal://files/work/demo',
buffer: buffer,
success: function () {
console.log('handling success')
},
fail: function (data, code) {
console.log(`handling fail, code = ${code}`)
}
})
file.readText(OBJECT)1010+
从文件中读取文本
参数:
参数名 |
类型 |
必填 |
说明 |
uri |
String |
是 |
本地文件路径 |
encoding |
String |
否 |
编码格式,默认 UTF-8 |
success |
Function |
否 |
成功回调 |
fail |
Function |
否 |
失败回调 |
complete |
Function |
否 |
执行结束后的回调 |
success返回值:
参数名 |
类型 |
说明 |
text |
String |
读取的文本 |
fail返回错误代码:
错误码 |
说明 |
202 |
参数错误 |
300 |
I/O 错误 |
301 |
文件不存在 |
示例:
file.readText({
uri: 'internal://files/work/demo.txt',
success: function (data) {
console.log('text: '+ data.text)
},
fail: function (data, code) {
console.log(`handling fail, code = ${code}`)
}
})
file.readArrayBuffer(OBJECT)1010+
从文件中读取Buffer
参数:
参数名 |
类型 |
必填 |
说明 |
uri |
String |
是 |
本地文件路径 |
position |
Number |
否 |
读取的起始位置,默认值为文件的起始位置 |
length |
Number |
否 |
读取的长度,不填写则读取到文件结尾 |
success |
Function |
否 |
成功回调 |
fail |
Function |
否 |
失败回调 |
complete |
Function |
否 |
执行结束后的回调 |
success返回值:
参数名 |
类型 |
说明 |
buffer |
Uint8Array |
读取的文件内容 |
fail返回错误代码:
错误码 |
说明 |
202 |
参数错误 |
300 |
I/O 错误 |
301 |
文件不存在 |
示例:
file.readArrayBuffer({
uri: 'internal://files/work/demo',
position: 100,
length: 100,
success: function (data) {
console.log('buffer.length: '+ data.buffer.length)
},
fail: function (data, code) {
console.log(`handling fail, code = ${code}`)
}
})
file.access(OBJECT)1060+
判断文件或目录是否存在
参数:
参数名 | 类型 | 必填 | 说明 |
---|
uri | String | 是 | 目录或文件 uri,不能是应用资源路径和 tmp 类型的 uri |
success | Function | 否 | 成功回调 |
fail | Function | 否 | 失败回调 |
complete | Function | 否 | 执行结束后的回调 |
fail 返回错误代码:
示例:
file.access({
uri: 'internal://files/test',
success: function(data) {
console.log(`handling success`)
},
fail: function(data, code) {
console.log(`handling fail, code = ${code}`)
}
})
file.mkdir(OBJECT)1060+
创建目录
参数:
参数名 | 类型 | 必填 | 说明 |
---|
uri | String | 是 | 目录的 uri,不能是应用资源路径和 tmp 类型的 uri |
recursive | Boolean | 否 | 是否递归创建该目录的上级目录后再创建该目录。默认 false |
success | Function | 否 | 成功回调 |
fail | Function | 否 | 失败回调 |
complete | Function | 否 | 执行结束后的回调 |
fail 返回错误代码:
示例:
file.mkdir({
uri: 'internal://files/dir/',
success: function(data) {
console.log(`handling success`)
},
fail: function(data, code) {
console.log(`handling fail, code = ${code}`)
}
})
file.rmdir(OBJECT)1060+
删除目录
参数:
参数名 | 类型 | 必填 | 说明 |
---|
uri | String | 是 | 目录的 uri,不能是应用资源路径和 tmp 类型的 uri |
recursive | Boolean | 否 | 是否递归删除子文件和子目录。默认 false |
success | Function | 否 | 成功回调 |
fail | Function | 否 | 失败回调 |
complete | Function | 否 | 执行结束后的回调 |
fail 返回错误代码:
示例:
file.rmdir({
uri: 'internal://files/dir/',
success: function(data) {
console.log(`handling success`)
},
fail: function(data, code) {
console.log(`handling fail, code = ${code}`)
}
})
后台运行限制
无限制。
后台运行详细用法参见 后台运行脚本。