- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想获取 Iframe 上的输入值。我想在单击主页上的按钮时获取此值。
好吧,我有这段代码
主页上的 JavaScript:
var targetDiv = document.getElementById('CP_dem');
主页上的 HTML:一个选项卡,当您单击它时,它会加载 Iframe和一个调用 javascript 函数的按钮
Iframe 上的 Html:
Zip Code : <input class="textForm" id="CP_dem" type="text" name="CP_dem" maxlength="5" size="5" value="42101">
我想在单击 MainPageButton 时获取输入值。
JavaScript 代码显示“targetDiv”为空。
你能帮我一下吗?谢谢
最佳答案
您必须告诉的第一件事是:
iframe 是否托管在与父网站相同的 http 主机上?如果没有,您将遇到 JavaScript 同源保护,请阅读:http://en.wikipedia.org/wiki/Same_origin_policy
简而言之:您将无法访问该内容。可是等等!有一个解决方法,我将在处理第二种情况后解释,其中 http 主机是相同的!
那么我们来谈谈第二种情况。那么工作就很容易了...
您只需访问 iframe(可能为 iframe 标记提供一个 id“example”)。然后您可以使用 example.contentWindow.document 或 example.contentDocument 访问该窗口
无论设置哪一个,都取决于浏览器。您将必须在 js 中进行一些检查。类似的东西
if(document.getElementById('contentWindow.document').contentWindow) {
ifdoc = document.getElementById('contentWindow.document').contentWindow.document
} else {
ifdoc = document.getElementById('contentWindow.document').contentDocument
}
然后你就可以像在 javascript 中一样访问表单和元素,我不会在这里介绍......
所以让我们跳到这个答案中有趣的部分!让我们围绕同源策略进行工作。这也称为“跨站点脚本”(继续用 google 搜索一下...)
所以基本上可以归结为一件事:
有一个属性可以从子文档和父文档访问!
它是 document.location 属性!
那么你能做什么呢?
子站点可以修改它,然后父站点可以监视它并对更改使用react。
另一个不错的功能是 url 片段(# 后面的部分)。这部分不会重新加载网站,因此 javascript 可以愉快地修改它,并且父站点可以定期轮询它并对其使用react...
基本上,这为可以处理的父子文档提供了沟通的基础。为此有设计精美的图书馆! javscript版本的“用facebook登录”也是基于同样的原理!
这意味着子文档必须与父文档合作,因此这是有意的,双方基本上一起工作。
所以这是可以的,而且它们可以围绕相同的源策略工作。
希望这从理论上涵盖了您的问题,并为您在实践中提供了一些东西!
祝您度过愉快的一天:)
关于javascript - 从 Iframe 获取值到 mainPage,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15481968/
这个问题在这里已经有了答案: final keyword in method parameters [duplicate] (9 个回答) 关闭 8 年前。 在此示例中,声明 Object fina
我的目标:是通过我的函数更新字段获取选定值并使用函数输出值运行它。 问题:当我从列表中选择值时,它不会触发函数,也不会更新字段。 感谢您的帮助。 HTML 12 14 16 18 20 22 24
我有一本具有这种形式的字典: myDict = {'foo': bar, 'foobar baz': qux} 现在,我想拆分字典键中的空格,使其成为下一个键并获取值(重复)。 myDictRev1
vector a; vector b; int temp_holder; cout > temp_holder) a.push_back(temp_holder); cout > temp_h
Java 的开发过程中免不了与 Date 类型纠缠,准备总结一下项目经常使用的日期相关操作,JDK 版本 1.7,如果能够帮助大家节约那么几分钟起身活动一下,去泡杯咖啡,便是极好的,嘿嘿。当然,我
我正在使用 jquery ui 日期选择器来获取 fromDate 和 toDate 以下是from日期的代码 $("#from_date").datepicker({
我是一名优秀的程序员,十分优秀!