gpt4 book ai didi

Angular 7 - 尝试在上传前创建音频文件的预览

转载 作者:搜寻专家 更新时间:2023-10-30 21:46:38 27 4
gpt4 key购买 nike

我想要的结果是在将音频文件上传到服务器之前创建它的预览。但是在文件输入后,没有任何反应。文件没有动态添加到 aduio 标签,我也没有收到任何错误。控制台显示文件已加载。任何帮助将不胜感激!

我的组件html有~

<audio controls #figAudio>
<source [src]="audSrc" type="audio/ogg">
<source [src]="audSrc" type="audio/mpeg">
<source [src]="audSrc" type="audio/wav">
</audio>
<input type="file" (change)="audFileSelected($event)">

我的组件ts文件有~

audSrc: SafeUrl;

constructor (
private sanitize: DomSanitizer
) {}

sanitizeUrl(url: string) {
return this.sanitize.bypassSecurityTrustUrl(url);
}

audFileSelected(event: any) {
console.log(event.target.files[0]);
if (event.target.files && event.target.files[0]) {
const reader = new FileReader();
reader.readAsDataURL(event.target.files[0]);
reader.onload = (evt: any) => {
this.audSrc = evt.target.result;
};
}
}

最佳答案

好的,我解决了这个问题。我没有使用 FileReader,而是使用了一个 URL 对象。然后,我使用自定义管道清理我的音频 URL。

component.ts文件~

@ViewChild('figAudio') figAudio: ElementRef; // audio tag reference
audSrc = 'path/to/default/sound.mpeg';

audFileSelected(event: any) {
if (event.target.files && event.target.files[0]) {
const audSrc = URL.createObjectURL(event.target.files[0]);
this.figAudio.nativeElement.src = this.audSrc;
}
}

component.html文件~

<audio #figAudio>
<source [src]="audSrc | sanitizerUrl" type="audio/ogg">
<source [src]="audSrc | sanitizerUrl" type="audio/mpeg">
<source [src]="audSrc | sanitizerUrl" type="audio/wav">
</audio>

sanitize-url.pipe.ts ~

@Pipe({
name: 'sanitizerUrl'
})
export class SanitizerUrlPipe implements PipeTransform {

constructor (
private sanitize: DomSanitizer
) {}

transform(value: string): SafeUrl {
return this.sanitize.bypassSecurityTrustUrl(value);
}
}

关于Angular 7 - 尝试在上传前创建音频文件的预览,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53946212/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com