当前位置: 首页 > 图文教程 > 网络编程 > Javascript > javascript不同页面传值的改进版

Javascript
Javascript实例教程(12) 隐藏script代码
Javascript实例教程(11) 创建\"后退\"按钮
HTC:浏览器上的舞者
JavaScript 小技巧(第四集)
Javascript实例教程(20) 使用HoTMetal(7)
点一下,首页地址添加到收藏夹(javascript)
Javascript设计漫天雪花
Javascript实例教程(21) OLE Automation(2)
Javascript实例教程(20) 使用HoTMetal(3)
Javascript制作闪烁的边框
JavaScript对象与数组参考大全
Javascript实例教程(21) OLE Automation(3)
利用JavaScript制作倒计时牌
Javascript实例教程(5) 利用Javascript创建对象
利用JAVASCRIPT制作简单动画
Javascript实例教程(15) JS代替CGI
Javascript实例教程(19) 数组
JavaScript[对象.属性]集锦之三
Javascript实例教程(21) OLE Automation(6)
JavaScript 小技巧(第一集)

Javascript 中的 javascript不同页面传值的改进版


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-10-12   浏览: 65 ::
收藏到网摘: n/a

改进点:支持同页面有多个文本框,可自动向不同的文本框传值。先看演示吧 其实原理也很简单。同样先通过getAttribute判断type属性,捕捉到按钮。然后在按钮onclick时把i通过url传入子页面。
复制代码 代码如下:

<h2>input1</h2>
<input type="text" /><input type="submit" />
<h2>input2</h2>
<input type="text" /><input type="submit" />
<script type="text/javascript"><!--
var aInput = document.getElementsByTagName("input");
for (i = 0 ; i < aInput.length ; i++ )
{
(
function (i){
if (aInput[i].getAttribute("type") == "submit")
{
aInput[i].onclick = function (){
window.open('b.html?'+i,'newwindow','height=100,width=400')
}
}
}
)(i)
}
// --></script>

子页面用slice方法对url进行切分。并使用window.opener方法捕捉到父页面的文本框,进行赋值。 一切就OK了
复制代码 代码如下:

<h2>openWindow</h2>
<input type="text" /><input type="submit" />
<script type="text/javascript"><!--
var aInput = document.getElementsByTagName("input");
for (i = 0 ; i < aInput.length ; i++ )
{
if (aInput[i].getAttribute("type") == "text") var textboxB = new Object(aInput[i]);
if (aInput[i].getAttribute("type") == "submit") var btnB = new Object(aInput[i]);
}
btnB.onclick = function(){
var sTextValue = textboxB.value
var aInput = window.opener.document.getElementsByTagName("input");
var sUrl = document.location;
var sNo = sUrl.toString().slice(-1)
window.opener.aInput[sNo-"1"].value = sTextValue
window.close();
}
// --></script>

还没明白的朋友看一下原理图就知道了