以 MVVM 方式处理 html5 视频标签的正确方法是什么?
What is the proper way to handle html5 video tags in an MVVM manner?
在我们基于 Durandal 的 SPA 中,我需要一个由我的视图模型严格控制的 html5 视频播放器。 视图模型将控制播放,搜索,时间显示,更改源等... 为此,我的视图模型需要直接引用 html 视频节点,以便它可以访问视频标签上的属性和函数。
现在最简单的方法是向我的视图添加一个空的视频标签,并使用 jquery 在我的视图模型的 compositionComplete()
函数中获取对它的引用。 但是,现在这已将我的视图模型与我的视图紧密耦合。
有没有办法让我在我的视图模型中创建 html 标记(通过 document.createElement('video')
),将其设置为我的视图模型的属性,然后让 KNOCKOUT 将其添加到页面中? 根据 knockoutjs 的文档,html:
数据绑定子句会将标记.ToString()
到 innerHtml
属性,因此 javascript 不会直接引用页面上表示的同一视频标记。
以 MVVM 方式执行此操作的正确方法是什么,或者我最好的选择是使用 jquery 提取视频标签?
谢谢
Edit
在进一步查看挖空绑定之后,我认为最好的解决方案是为每个视频方法和属性创建自定义绑定:
<video data-bind='sources: sourcesArr, volume: videoVolume, playback: playbackState, ...'> </video>
sourcesArr 将是一个可观察的数组
体积将是一个可观察的整数
playbackState 将是一个具有"播放"或"暂停"值的可观察字符串
源语言
我认为(也许)您可以像这样创建一个视频视图模型和视频自定义绑定
<video data-bind='video: videoViewModel'> </video>
跟进我对LostInComputer答案的评论:
ko.bindingHandlers.el={
init: function(element, valueAccessor) {
valueAccessor()(element);
}
};
用作:
<video data-bind="el: myVideoElement, ..."></video>
现在myVideoElement()
将为您提供视频的 DOM 元素。
- 打破承诺链的好方法是什么
- 在JavaScript中拆分日期字符串的更好方法是什么
- 将jQuery.ech()方法转换为本地JavaScript抽象的最佳方法是什么
- 处理浮点错误的最佳方法是什么
- 基于窗口宽度jquery的函数的替代方法是什么
- knex:根据结果创建数组的合适方法是什么
- 以编程方式填充组合框道场 (1.8) 的最佳方法是什么?
- 使用Modernizr检测移动设备最可靠的方法是什么
- 确定var是否是javascript中的elementFinder对象的方法是什么
- 用javascript修复这个JSON对象字符串最干净的方法是什么
- 让会话值可用于JavaScript的好方法是什么
- 从AngularJs获取谷歌地图对象的正确方法是什么
- 使用ReactJS和Flux架构从服务器获取数据的正确方法是什么
- 列出没有 mysql 的元素的最佳方法是什么
- 克服错误的更优雅的方法是什么:需要对象说明符.当通过JXA通过Messages发送SMS时,参数没有对象说明符
- 使用较少代码隐藏和显示选择菜单内容的更好方法是什么?javascript
- 在 Javascript 中实现解耦代码/回调的正确方法是什么?
- 使用Javascript,获取元素的方法是什么,基于打开和关闭标记之间的文本
- 在d3.json中使用d3.csv组合多个csv文件数据输入的最佳方法是什么
- 直接在DOM事件处理程序中调用作用域函数的最短方法是什么