useScriptTag
创建一个脚本标签,支持在组件卸载时自动卸载 (删除) 脚本标签。
如果给定 URL 的脚本标签已经存在,useScriptTag()
将不会创建另一个脚本标签,但请注意,根据你的使用方式,useScriptTag()
可能已经从之前的 useScriptTag()
调用中加载并卸载了该特定的 JS 文件。
用法
ts
import { useScriptTag } from '@vueuse/core'
useScriptTag(
'https://player.twitch.tv/js/embed/v1.js',
// 当脚本标签加载完成时的回调。
(el: HTMLScriptElement) => {
// 做一些事情
},
)
js
import { useScriptTag } from '@vueuse/core'
useScriptTag(
'https://player.twitch.tv/js/embed/v1.js',
// 当脚本标签加载完成时的回调。
(el) => {
// 做一些事情
},
)
该脚本将在组件挂载时自动加载,并在组件卸载时删除。
配置
设置 manual: true
以手动控制加载脚本的时机。
ts
import { useScriptTag } from '@vueuse/core'
const { scriptTag, load, unload } = useScriptTag(
'https://player.twitch.tv/js/embed/v1.js',
() => {
// 做一些事情
},
{ manual: true },
)
// 手动控制
await load()
await unload()
类型声明
显示类型声明
typescript
export interface UseScriptTagOptions extends ConfigurableDocument {
/**
* 立即加载脚本
*
* @default true
*/
immediate?: boolean
/**
* 在脚本标签中添加 `async` 属性
*
* @default true
*/
async?: boolean
/**
* 脚本类型
*
* @default 'text/javascript'
*/
type?: string
/**
* 手动控制加载和卸载的时机
*
* @default false
*/
manual?: boolean
crossOrigin?: "anonymous" | "use-credentials"
referrerPolicy?:
| "no-referrer"
| "no-referrer-when-downgrade"
| "origin"
| "origin-when-cross-origin"
| "same-origin"
| "strict-origin"
| "strict-origin-when-cross-origin"
| "unsafe-url"
noModule?: boolean
defer?: boolean
/**
* 在脚本标签中添加自定义属性
*
*/
attrs?: Record<string, string>
}
/**
* 异步加载脚本标签。
*
* @see https://vueuse.org/useScriptTag
* @param src
* @param onLoaded
* @param options
*/
export declare function useScriptTag(
src: MaybeRefOrGetter<string>,
onLoaded?: (el: HTMLScriptElement) => void,
options?: UseScriptTagOptions,
): {
scriptTag: Ref<HTMLScriptElement | null, HTMLScriptElement | null>
load: (waitForScriptLoad?: boolean) => Promise<HTMLScriptElement | boolean>
unload: () => void
}
export type UseScriptTagReturn = ReturnType<typeof useScriptTag>
源码
贡献者
Anthony Fu
一纸忘忧
Anthony Fu
Denis Blazhkun
Fernando Fernández
Robin
Craig Riley
David B Ludlow
Levi (Nguyễn Lương Huy)
Tomáš Livora
webfansplz
Preston Alvarado
Shinigami
Alex Kozack
Yaël GUILLOUX
更新日志
Pending for release...
v12.3.0
on 1/2/202559f75
- feat(toValue): deprecate toValue
from @vueuse/shared
in favor of Vue's nativev12.0.0-beta.1
on 11/21/2024v10.0.0-beta.4
on 4/13/20234d757
- feat(types)!: rename MaybeComputedRef
to MaybeRefOrGetter
0a72b
- feat(toValue): rename resolveUnref
to toValue