document.createElement在ie9与firefox中无效怎么办
若以下回答无法解决问题,邀请你更新回答
1个回答
展开全部
input元素的创建:与 input 有关的元素有很多,比如:checkbox、radio、submit、reset...,因此创建 input 是个很特殊的用法。
创建不同的 input 正确的做法是:
<div id="board"></div>
<script type="text/javascript">
<!--
var board = document.getelementbyid("board");
var e = document.createelement("input");
e.type = "radio"; //紧接着上一行写
var obj = board.appendchild(e);
obj.checked = true;
//如下写法也是正确的:
//e.checked = true;
-->
</script>
针对 input,在 netscape、opera 和 firefox 中 e.type 既可以在 appendchild 之前,也可以在其之后。但在 ie 中 type 属性必须在前,其它属性必须在后。
ie 创建元素,还有一个特点,就是可以连同属性一同创建,比如:var e = document.createelement("<input type='radio' name='r' value='1' />"); 这在其它浏览器中是不行的,所以我们也不支持。
总结:
针对非 input 元素,各浏览器中,既可以把对元素属性的改变写在显示元素(insertbefore 或 appendchild)之前,也可以在其后。
针对 input 元素,为了兼容 ie,type 属性写在显示元素(insertbefore 或 appendchild)之前,其它属性写在其后。
推荐:
除了 input 元素的 type 属性写在显示元素(insertbefore 或 appendchild)之前外,其它属性都写在显示元素之后。
改变属性时,对写在显示元素(insertbefore 或 appendchild)之前的用 createelement 的返回值,对写在显示元素之后的用 insertbefore 或 appendchild 的返回值。
var echkbox=document.createelement("input");
echkbox.setattribute("type","checkbox");
echkbox.setattribute("id","inputid");
echkbox.setattribute("name","inputname");
echkbox.setattribute("value","inputvalue");
var addhere=document.getelementbyid("someelementid");
addhere.appendchild(echkbox);
echkbox.setattribute("checked","checked");
alert(document.getelementbyid("inputid").checked);
<!--document方法:
getelementbyid(id) 返回指定结点的引用
getelementsbytagname(name) 返回文档中所有匹配的元素的集合
createelement(name) 创建指定类型的新结点
createtextnode(text) 创建一个纯文本结点
element方法:
getattribute(id) 返回指定属性的值
setattribute(id,value) 给属性赋值
removeattribute(id) 移除指定属性和它的值
getelementsbytagname(name) 返回结点内所有匹配的元素的集合
node方法:
appendchild(child) 给指定结点添加一个新的子结点
removechild(child) 移除指定结点的子结点
replacechild(newchild,oldchild) 替换指定结点的子结点
insertbefore(newchild,refchild) 在同一层级的结点前面插入新结点
haschildnodes() 如果结点有子结点则返回true
node属性:
nodename 以字符串的格式存放结点的名称
nodetype 以整型数据格式存放结点的类型
nodevalue 以可用的格式存放结点的值
parentnode 指向结点的父结点的引用
childnodes 指向子结点的引用的集合
firstchild 指向子结点结合中的第一个子结点的引用
lastchild 指向子结点结合
此文来自: 马开东博客 转载请注明出处 网址: http://www.makaidong.com
中的最后一个子结点的引用
动态加载js
var rash=true;
var msg="";
function norash()
{
if (confirm("确定要取消吗"))
rash=false;
}
function rashit()
{
setinterval('getrss()',inttime);
}
function getrss()
{
if (rash==true)
{
head=document.getelementsbytagname('head').item(0);
script=document.createelement('script');
script.src='include/autoupdate.asp';
script.type='text/javascript';
script.defer=true;
void(head.appendchild(script));
window.status=msg;
}
}
rashit();
/----------------------------直接可以使用此方法创建
var echkbox=document.createelement("input");
echkbox.setattribute("type","checkbox");
echkbox.setattribute("id","inputid");
echkbox.setattribute("name","inputname");
echkbox.setattribute("value","inputvalue");
创建不同的 input 正确的做法是:
<div id="board"></div>
<script type="text/javascript">
<!--
var board = document.getelementbyid("board");
var e = document.createelement("input");
e.type = "radio"; //紧接着上一行写
var obj = board.appendchild(e);
obj.checked = true;
//如下写法也是正确的:
//e.checked = true;
-->
</script>
针对 input,在 netscape、opera 和 firefox 中 e.type 既可以在 appendchild 之前,也可以在其之后。但在 ie 中 type 属性必须在前,其它属性必须在后。
ie 创建元素,还有一个特点,就是可以连同属性一同创建,比如:var e = document.createelement("<input type='radio' name='r' value='1' />"); 这在其它浏览器中是不行的,所以我们也不支持。
总结:
针对非 input 元素,各浏览器中,既可以把对元素属性的改变写在显示元素(insertbefore 或 appendchild)之前,也可以在其后。
针对 input 元素,为了兼容 ie,type 属性写在显示元素(insertbefore 或 appendchild)之前,其它属性写在其后。
推荐:
除了 input 元素的 type 属性写在显示元素(insertbefore 或 appendchild)之前外,其它属性都写在显示元素之后。
改变属性时,对写在显示元素(insertbefore 或 appendchild)之前的用 createelement 的返回值,对写在显示元素之后的用 insertbefore 或 appendchild 的返回值。
var echkbox=document.createelement("input");
echkbox.setattribute("type","checkbox");
echkbox.setattribute("id","inputid");
echkbox.setattribute("name","inputname");
echkbox.setattribute("value","inputvalue");
var addhere=document.getelementbyid("someelementid");
addhere.appendchild(echkbox);
echkbox.setattribute("checked","checked");
alert(document.getelementbyid("inputid").checked);
<!--document方法:
getelementbyid(id) 返回指定结点的引用
getelementsbytagname(name) 返回文档中所有匹配的元素的集合
createelement(name) 创建指定类型的新结点
createtextnode(text) 创建一个纯文本结点
element方法:
getattribute(id) 返回指定属性的值
setattribute(id,value) 给属性赋值
removeattribute(id) 移除指定属性和它的值
getelementsbytagname(name) 返回结点内所有匹配的元素的集合
node方法:
appendchild(child) 给指定结点添加一个新的子结点
removechild(child) 移除指定结点的子结点
replacechild(newchild,oldchild) 替换指定结点的子结点
insertbefore(newchild,refchild) 在同一层级的结点前面插入新结点
haschildnodes() 如果结点有子结点则返回true
node属性:
nodename 以字符串的格式存放结点的名称
nodetype 以整型数据格式存放结点的类型
nodevalue 以可用的格式存放结点的值
parentnode 指向结点的父结点的引用
childnodes 指向子结点的引用的集合
firstchild 指向子结点结合中的第一个子结点的引用
lastchild 指向子结点结合
此文来自: 马开东博客 转载请注明出处 网址: http://www.makaidong.com
中的最后一个子结点的引用
动态加载js
var rash=true;
var msg="";
function norash()
{
if (confirm("确定要取消吗"))
rash=false;
}
function rashit()
{
setinterval('getrss()',inttime);
}
function getrss()
{
if (rash==true)
{
head=document.getelementsbytagname('head').item(0);
script=document.createelement('script');
script.src='include/autoupdate.asp';
script.type='text/javascript';
script.defer=true;
void(head.appendchild(script));
window.status=msg;
}
}
rashit();
/----------------------------直接可以使用此方法创建
var echkbox=document.createelement("input");
echkbox.setattribute("type","checkbox");
echkbox.setattribute("id","inputid");
echkbox.setattribute("name","inputname");
echkbox.setattribute("value","inputvalue");
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询