angular.js - 可以通過vue或者angular雙向數據綁定iframe元素嗎?
問題描述
請教一下開發一個H5游戲的管理系統,想在后臺輸入內容的時候iframe里面的頁面元素即時同步內容,想咨詢下用什么技術可以實現?vue和angular可以實現嗎?
效果如下圖:
問題解答
回答1:parent.html
<p id='app'> <input type='text' v-model='item.name' /> <input type='checkbox' v-model='item.check' /> <input type='date' v-model='item.date' /> <iframe ref='iframe' src='http://www.aoyou183.cn/wenda/child.html' @load='load'></iframe></p><script src='http://cdn.bootcss.com/vue/2.1.8/vue.min.js'></script><script> window.app = new Vue({el: ’#app’,data() { return {item: { name: null, check: false, date: null,}, }},methods: { load: function (item) {const app = this.$refs.iframe.contentWindow.app;if (app && app.setContent) { app.setContent(this.item)}else { window._item = this.item} }} })</script>
child.html
<p id='app'> {{ item }}</p><script src='http://cdn.bootcss.com/vue/2.1.8/vue.min.js'></script><script> window.app = new Vue({el: ’#app’,data() { return {item: null, }},created: function () { this.setContent(window.parent.window._item);},methods: { setContent: function (item) {this.item = item; }} })</script>
或者傳遞vuex的store 2個頁面的vue實例用同一個store
回答2:你用iframe的話只能用websocket來通知更新了,vue和ag的雙向數據是在同一頁面才可以實時更新的
回答3:iframe屬于跨頁面了,如果別人可以用ng或者vue就可以操作你的頁面是極不安全的,也是不可能的。
你可以試試postMessage。
相關文章:
1. android - NavigationView 的側滑菜單中如何保存新增項(通過程序添加)2. tp5 不同控制器中的變量調用問題3. 微信小程序可以用gulp,webpack嗎?4. mysql服務無法啟動1067錯誤,誰知道正確的解決方法?5. ueditor上傳服務器提示后端配置項沒有正常加載,求助!!!!!6. python - 為什么正常輸出中文沒有亂碼,zip函數之后出現中文編程unicode編碼的問題,我是遍歷輸出的啊。7. 老師 我是一個沒有學過php語言的準畢業生 我希望您能幫我一下8. 這段代碼既不提示錯誤也看不到結果,請老師明示錯在哪里,謝謝!9. php7.3.4中怎么開啟pdo驅動10. 提示語法錯誤語法錯誤: unexpected ’abstract’ (T_ABSTRACT)
