js通过视频链接获取视频时长
这个函数用提供的url创建一个新的video元素,并在loadedmetadata事件被触发时解析一个带有视频持续时间的promise。它还处理可能发生的任何错误。
注意,video元素的duration属性是以秒为单位的,因此如果需要,您可能希望将其转换为更易于阅读的格式。
function getvideoduration(url) {
return new promise((resolve, reject) => {
const video = document.createelement('video');
video.src = url;
video.addeventlistener('loadedmetadata', () => {
resolve(video.duration);
video.remove();
});
video.addeventlistener('error', () => {
resolve(null);
video.remove();
});
document.body.appendchild(video);
});
}
// example usage
const videourl = 'https://www.example.com/video.mp4';
getvideoduration(videourl)
.then((duration) => {
if (duration) {
console.log('video duration:', duration);
} else {
console.log('failed to get video duration');
}
});js--获取上传视频文件的时长(秒)
代码基于ng-zorro组件,适当参考哈:
beforevideoupload = (file: file) => {
return new observable((observer: observer<boolean>) => {
// 判断文件类型
const isvideofile = /video\/(wmv|asf|asx|rm|rmvb|mpg|mpeg|mpe|3gp|mov|mp4|m4v|avi|dat|mkv|flv|vob)$/.test(file.type);
console.log('是否为视频类型:', isvideofile);
// 获取视频时长
const url = url.createobjecturl(file);
const audioelement = new audio(url);
let videoseconds;
audioelement.addeventlistener('loadedmetadata', (_event) => {
videoseconds = math.floor(audioelement.duration);
console.log('视频时长为', videoseconds);
observer.next(true);
observer.complete();
});
});
};到此这篇关于js如何通过视频链接获取视频时长的文章就介绍到这了,更多相关js获取视频时长内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!
发表评论