Skip to content

useObjectUrl

类别
导出体积
263 B
上次更改
3 weeks ago

响应式对象的 URL。

通过 URL.createObjectURL() 为提供的 FileBlobMediaSource 创建一个 URL,并在源发生变化或组件卸载时自动释放 URL,通过 URL.revokeObjectURL() 实现。

示例

选择文件:
Object URL:
none

使用方法

vue
<script setup>
import { useObjectUrl } from '@vueuse/core'
import { shallowRef } from 'vue'

const file = shallowRef()
const url = useObjectUrl(file)

function onFileChange(event) {
  file.value = event.target.files[0]
}
</script>

<template>
  <input type="file" @change="onFileChange">

  <a :href="url">打开文件</a>
</template>

组件使用

vue
<template>
  <UseObjectUrl v-slot="url" :object="file">
    <a :href="url">打开文件</a>
  </UseObjectUrl>
</template>

类型声明

typescript
/**
 * 响应式 Object URL
 *
 * @see https://vueuse.org/useObjectUrl
 * @param object
 */
export declare function useObjectUrl(
  object: MaybeRefOrGetter<Blob | MediaSource | null | undefined>,
): Readonly<Ref<string | undefined, string | undefined>>

源码

源码演示文档

贡献者

Anthony Fu
一纸忘忧
Anthony Fu
Andrew Ferreira
vaakian X
BaboonKing
Michael Hüneburg

更新日志

v12.3.0 on 1/2/2025
59f75 - feat(toValue): deprecate toValue from @vueuse/shared in favor of Vue's native
v12.0.0-beta.1 on 11/21/2024
0a9ed - feat!: drop Vue 2 support, optimize bundles and clean up (#4349)
v10.3.0 on 7/30/2023
d3f7e - fix: improve parameter type (#3239)
v9.11.0 on 1/17/2023
d5321 - fix(components): mark defineComponent as pure (#2623)