<html><frameset> <frame id='top',js实现frameset/iframe的传值赋值与取值

今天抽了点时间整理了下有关frameset和iframe之间的一些常见的操作:取值、赋值

先上一个frameset框架

index.html

这是常见的布局格式,顶部一个top,下方是左右两个页面

功能一:实现主体布局frame间传值与取值;

如:right.html操作main.html

main.htmlmain.html


尝试传值给下方iframe

尝试获取下方iframe中输入框的内容



$(function(){

$("#small").click(function(){

var obj;

//obj=$(document.getElementById('smallFrame').contentWindow.document.body).html(); //对的

obj=$(document.getElementById('smallFrame').contentWindow.document.body);

$('#small',obj).html('main.html控制当前文档下iframe(small.html)的内容');

return false;

});

$("#getsmallElement").click(function(){

var obj=$(document.getElementById('smallFrame').contentWindow.document.body);

alert($('#inp',obj).val());

return false;

});

})

1、给id=categoryid的div传值,在right.html中写到var obj;

/*设置同级frame中元素的内容*/

obj=$(window.parent.document.getElementById('mainFrame').contentWindow.document.body);

$(obj).find("#categoryid").html('right.html控制main.html的内容');

//或

//$(window.parent.document.getElementById('mainFrame').contentWindow.document.body).find('#categoryid').html('来自right.html的内容');

return false;

2、取id=inp输入框的值,在right.html中写到var obj=$(window.parent.document.getElementById('mainFrame').contentWindow.document.body);

alert($('#inp',obj).val());

return false;

功能二:实现当前页面对iframe页面的传值与取值

如:main.html对其中iframe(small.html)进行操作

small.htmlsmall.html


1、给id=small的div进行传值,在main.html中写到var obj;

//obj=$(document.getElementById('smallFrame').contentWindow.document.body).html(); //对的

obj=$(document.getElementById('smallFrame').contentWindow.document.body);

$('#small',obj).html('main.html控制当前文档下iframe(small.html)的内容');

return false;

2、取id=inp输入框的值,在main.html中写到var obj=$(document.getElementById('smallFrame').contentWindow.document.body);

alert($('#inp',obj).val());

主要功能代码:

A、在frameset中获取同级frame对应页面对象中的bodyvar obj=$(window.parent.document.getElementById('mainFrame').contentWindow.document.body)

B、获取当前页面下iframe对应页面对象中的bodyvar obj=$(document.getElementById('smallFrame').contentWindow.document.body);

该方法不能实现跨域

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值