关于动态写入表格问题的扩展
2008-05-23 13:39
246 查看
这里有几个问题
1.跨浏览器支持 (水平有限,目前只研究FF和IE)
2特殊字符处理
3除了TEXT以外的元素对象数据插入,比如DROPDOWNLIST
下面将一一解决,大牛们如果有更好解决方法,欢迎指教。。。
1 跨浏览器支持,此问题产生于输入数据源为iFrame类型的,因为在不同的浏览器下,获取iFrame的对象方法是不同的
if (window.navigator.userAgent.indexOf("MSIE")>=1)
{
//如果浏览器为IE
var gl_doc = document.getElementById("frame_check").Document;
}else if(window.navigator.userAgent.indexOf("Firefox")>=1)
{
//如果浏览器为Firefox
var gl_doc = document.getElementById("frame_check").contentDocument;
}
else
{
return false;
}
id为frame_check的对象,是在本页中的iFrame的ID
获得此对象后,就可以根据他,来获得用户输入的信息了
var Defname = gl_doc.getElementById("Defname");
var Defdesp = gl_doc.getElementById("Defdesp");
var Defcode = gl_doc.getElementById("Defcode");
var Deftype = gl_doc.getElementById("Deftype");
var FlagType = gl_doc.getElementById("FlagType");
var Deflable = gl_doc.getElementById("FlagText");
2关于特殊字符的处理,此问题产生于带描述字段的动态表格,解决办法如下
//全局变量记录信息条数
var count=0;
//全局变量,目的是使innerHTML进表格的SPAN不重复
var tab_n=0;
//添加表格
var x=document.getElementById('myTable').insertRow(count -1);
var b=x.insertCell(0);
//先向里面写入一个SPAN对象
b.innerHTML="<span id="show_str"+tab_n+""></span>";
if(document.all) //如果是IE
{
if(getvalue.value.length>15)
{
//设置显示多少个字符
document.getElementById("show_str"+tab_n).innerText=getvalue.value.substr(0,15)+"...";
//如果超出,用TITLE形式显示
document.getElementById("show_str"+tab_n).title=getvalue.value;
}
else
{
document.getElementById("show_str"+tab_n).innerText=getvalue.value;
}
}
else //如果是FF
{
if(getvalue.value.length>15)
{
document.getElementById("show_str"+tab_n).textContent=getvalue.value.substr(0,15)+"...";
document.getElementById("show_str"+tab_n).title=getvalue.value;
}
else
{
document.getElementById("show_str"+tab_n).textContent=getvalue.value;
}
}
这里主要是innerHTML,innerText 和 textContext几个方法的结合使用
3在IE和FF下,当DropDownList的
值和显示的内容不一致的时候,如何获取DropDownList的显示内容,并填入表格。
//同时获得选择框Value和Option开始
var devid=document.getElementById("devid")
if(devid.value=="")
{
alert("设备不可为空");
return false;
}
var roleid=document.getElementById("roleid")
for (var i=0;i<devid.options.length; i++)
{
if (devid.options[i].value==devid.value){
if (window.navigator.userAgent.indexOf("MSIE")>=1)
{
//如果浏览器为IE
var devidvalue=devid.options[i].innerText;
}else if(window.navigator.userAgent.indexOf("Firefox")>=1)
{
//如果浏览器为Firefox
var devidvalue=devid.options[i].textContent;
}
else{
return false;
}
}
}
for (var j=0;j<roleid.options.length; j++)
{
if (roleid.options[j].value==roleid.value){
if (window.navigator.userAgent.indexOf("MSIE")>=1)
{
//如果浏览器为IE
var roleidvalue=roleid.options[j].innerText;
}else if(window.navigator.userAgent.indexOf("Firefox")>=1)
{
//如果浏览器为Firefox
var roleidvalue=roleid.options[j].textContent;
}
else{
return false;
}
}
}
处理情况同上
效果如下
1.跨浏览器支持 (水平有限,目前只研究FF和IE)
2特殊字符处理
3除了TEXT以外的元素对象数据插入,比如DROPDOWNLIST
下面将一一解决,大牛们如果有更好解决方法,欢迎指教。。。
1 跨浏览器支持,此问题产生于输入数据源为iFrame类型的,因为在不同的浏览器下,获取iFrame的对象方法是不同的
if (window.navigator.userAgent.indexOf("MSIE")>=1)
{
//如果浏览器为IE
var gl_doc = document.getElementById("frame_check").Document;
}else if(window.navigator.userAgent.indexOf("Firefox")>=1)
{
//如果浏览器为Firefox
var gl_doc = document.getElementById("frame_check").contentDocument;
}
else
{
return false;
}
id为frame_check的对象,是在本页中的iFrame的ID
获得此对象后,就可以根据他,来获得用户输入的信息了
var Defname = gl_doc.getElementById("Defname");
var Defdesp = gl_doc.getElementById("Defdesp");
var Defcode = gl_doc.getElementById("Defcode");
var Deftype = gl_doc.getElementById("Deftype");
var FlagType = gl_doc.getElementById("FlagType");
var Deflable = gl_doc.getElementById("FlagText");
2关于特殊字符的处理,此问题产生于带描述字段的动态表格,解决办法如下
//全局变量记录信息条数
var count=0;
//全局变量,目的是使innerHTML进表格的SPAN不重复
var tab_n=0;
//添加表格
var x=document.getElementById('myTable').insertRow(count -1);
var b=x.insertCell(0);
//先向里面写入一个SPAN对象
b.innerHTML="<span id="show_str"+tab_n+""></span>";
if(document.all) //如果是IE
{
if(getvalue.value.length>15)
{
//设置显示多少个字符
document.getElementById("show_str"+tab_n).innerText=getvalue.value.substr(0,15)+"...";
//如果超出,用TITLE形式显示
document.getElementById("show_str"+tab_n).title=getvalue.value;
}
else
{
document.getElementById("show_str"+tab_n).innerText=getvalue.value;
}
}
else //如果是FF
{
if(getvalue.value.length>15)
{
document.getElementById("show_str"+tab_n).textContent=getvalue.value.substr(0,15)+"...";
document.getElementById("show_str"+tab_n).title=getvalue.value;
}
else
{
document.getElementById("show_str"+tab_n).textContent=getvalue.value;
}
}
这里主要是innerHTML,innerText 和 textContext几个方法的结合使用
3在IE和FF下,当DropDownList的
值和显示的内容不一致的时候,如何获取DropDownList的显示内容,并填入表格。
//同时获得选择框Value和Option开始
var devid=document.getElementById("devid")
if(devid.value=="")
{
alert("设备不可为空");
return false;
}
var roleid=document.getElementById("roleid")
for (var i=0;i<devid.options.length; i++)
{
if (devid.options[i].value==devid.value){
if (window.navigator.userAgent.indexOf("MSIE")>=1)
{
//如果浏览器为IE
var devidvalue=devid.options[i].innerText;
}else if(window.navigator.userAgent.indexOf("Firefox")>=1)
{
//如果浏览器为Firefox
var devidvalue=devid.options[i].textContent;
}
else{
return false;
}
}
}
for (var j=0;j<roleid.options.length; j++)
{
if (roleid.options[j].value==roleid.value){
if (window.navigator.userAgent.indexOf("MSIE")>=1)
{
//如果浏览器为IE
var roleidvalue=roleid.options[j].innerText;
}else if(window.navigator.userAgent.indexOf("Firefox")>=1)
{
//如果浏览器为Firefox
var roleidvalue=roleid.options[j].textContent;
}
else{
return false;
}
}
}
处理情况同上
效果如下
相关文章推荐
- 既然在 关于动态写入表格问题的扩展 中提到了iFrame,咱就不能不说说iFrame高度自适应问题
- JavaScript 关于动态添加表格行问题
- 关于扩展 Laravel 默认 Session 中间件导致的 Session 写入失效问题分析
- 关于利用juqery eq()和remove()动态删除表格中的行时遇到的问题
- 小女子需要各位博友帮忙—— 一个关于JS 动态表格合并拆分问题
- 关于扩展 Laravel 默认 Session 中间件导致的 Session 写入失效问题分析
- 关于jquery实现动态创建表格和动态显示数据的问题?
- 关于动态加载用户控件的问题
- 关于表格控件操作的问题
- 关于动态贴图问题不能动态通过texture改变只能重新new 新material
- 关于表格动态添加行并处理相关表单元素的一些修改----优化for重用(2)
- 关于asp.net中动态获取LinkButton的Text值的问题
- 关于linux动态链接共享库(如何解决应用程序跑不起来not found等问题)
- 关于kafka内存溢出,和数据不能写入问题
- 关于mybatis插件tk.mybatis生成的动态sql语句字段不加``的问题
- 关于mnt/sdcard一直不能写入的问题
- 关于android 中控件位置动态设置的问题
- jquery关于表格隐藏和显示问题
- 关于6位数码管动态扫描显示程序的一些问题
- 智渔课堂官方免费教程二(拓展):关于解决新建文件没有扩展名的问题