首页技术setattribute用法?setattribute的两个参数

setattribute用法?setattribute的两个参数

编程之家2026-06-05711次浏览

大家好,今天小编来为大家解答setattribute用法这个问题,setattribute的两个参数很多人还不知道,现在让我们一起来看看吧!

setattribute用法?setattribute的两个参数

setAttribute具体用法是什么

setAttribute这个方法,在JSP内置对象session和request都有这个方法,这个方法作用就是保存数据,然后还可以用getAttribute方法来取出。

比如现在又个User对象,Usercurruser=newUser("zhangsan",20,"男");

1,request.setAttribute(“curruser”,curruser)这个方法是将curruser这个对象保存在request作用域中,然后在转发进入的页面就可以获取到你的值,如果你会一些框架的话,那些框架标签也可以获取到,比如struts标签,还有jstl。如果这你都不会的话,那么你可以在jsp页面编写java小脚本来获取:<%Usermyuser=(User)request.getAttribute("curruser")%>,在jsp页面显示值:<%=myuser.getName()%>。

2,session.setAttribute("curruser",curruser)。这个方法和上面唯一的区别就是作用域,就是在你整个程序启动的时候,如果在session中保存了数据,那么在你这个无论你在哪个页面,在什么时候都可以获取到这个值,全局的,只要你的这个程序是启动的。session默认的过期时间是30分钟,过期无效,可以去修改这个值。

asp.net(c#) 中xml具体用法

asp.net创建xml就是通过创建DataTable来创建xml中的树型等

1 DataSet objset=new DataSet();

setattribute用法?setattribute的两个参数

2 DataTable istable=new DataTable("test");

3 istable.Columns.Add("rate1",typeof(int));

4 istable.Columns.Add("rate2",typeof(int));

5 istable.Columns.Add("rate3",typeof(int));

6 istable.Columns.Add("rate4",typeof(int));

7 objset.Tables.Add(istable);

setattribute用法?setattribute的两个参数

8

9 DataRow dr=objset.Tables["test"].NewRow();

10 dr[0]=赋值;

11 dr[1]=赋值;

12 dr[2]=赋值;

13 dr[3]=赋值;

14 objset.Tables["money"].Rows.Add(dr);

15

16 objset.WriteXml(Server.MapPath("test.xml"),XmlWriteMode.WriteSchema);

其中就是先创建DataSet和DataTable,其中建立的表为test,再在表中添加子项rate1,2,3,4,再定义新的行,分别添加对应的值,最后这些都已经写进DataSet表中,通过DataSet把xml输入就完成了。要读就只需要把xml的数据读到DataSet中,再通过 DataSet中的表的项来对应读出数据。

而C#中则使用的DOM来实现操作,比如现有一个bookstore.xml文件,内容如下

<?xml version="1.0" encoding="gb2312"?>

<bookstore>

<book genre="fantasy" ISBN="2-3631-4">

<title>Oberon's Legacy</title>

<author>Corets, Eva</author>

<price>5.95</price>

</book>

</bookstore>

下面讲解4种常用的方法

1、往<bookstore>节点中插入一个<book>节点:

XmlDocument xmlDoc=new XmlDocument();

xmlDoc.Load("bookstore.xml");

XmlNode root=xmlDoc.SelectSingleNode("bookstore");//查找<bookstore>

XmlElement xe1=xmlDoc.CreateElement("book");//创建一个<book>节点

xe1.SetAttribute("genre","李赞红");//设置该节点genre属性

xe1.SetAttribute("ISBN","2-3631-4");//设置该节点ISBN属性

XmlElement xesub1=xmlDoc.CreateElement("title");

xesub1.InnerText="CS从入门到精通";//设置文本节点

xe1.AppendChild(xesub1);//添加到<book>节点中

XmlElement xesub2=xmlDoc.CreateElement("author");

xesub2.InnerText="候捷";

xe1.AppendChild(xesub2);

XmlElement xesub3=xmlDoc.CreateElement("price");

xesub3.InnerText="58.3";

xe1.AppendChild(xesub3);

root.AppendChild(xe1);//添加到<bookstore>节点中

xmlDoc.Save("bookstore.xml");

//================

结果为:

<?xml version="1.0" encoding="gb2312"?>

<bookstore>

<book genre="fantasy" ISBN="2-3631-4">

<title>Oberon's Legacy</title>

<author>Corets, Eva</author>

<price>5.95</price>

</book>

<book genre="李赞红" ISBN="2-3631-4">

<title>CS从入门到精通</title>

<author>候捷</author>

<price>58.3</price>

</book>

</bookstore>

2、修改节点:将genre属性值为“李赞红“的节点的genre值改为“update李赞红”,将该节点的子节点<author>的文本修改为“亚胜”。

XmlNodeList nodeList=xmlDoc.SelectSingleNode("bookstore").ChildNodes;//获取bookstore节点的所有子节点

foreach(XmlNode xn in nodeList)//遍历所有子节点

{

XmlElement xe=(XmlElement)xn;//将子节点类型转换为XmlElement类型

if(xe.GetAttribute("genre")=="李赞红")//如果genre属性值为“李赞红”

{

xe.SetAttribute("genre","update李赞红");//则修改该属性为“update李赞红”

XmlNodeList nls=xe.ChildNodes;//继续获取xe子节点的所有子节点

foreach(XmlNode xn1 in nls)//遍历

{

XmlElement xe2=(XmlElement)xn1;//转换类型

if(xe2.Name=="author")//如果找到

{

xe2.InnerText="亚胜";//则修改

break;//找到退出来就可以了

}

}

break;

}

}

xmlDoc.Save("bookstore.xml");//保存。

//=================

最后结果为:

<?xml version="1.0" encoding="gb2312"?>

<bookstore>

<book genre="fantasy" ISBN="2-3631-4">

<title>Oberon's Legacy</title>

<author>Corets, Eva</author>

<price>5.95</price>

</book>

<book genre="update李赞红" ISBN="2-3631-4">

<title>CS从入门到精通</title>

<author>亚胜</author>

<price>58.3</price>

</book>

</bookstore>

3、删除<book genre="fantasy" ISBN="2-3631-4">节点的genre属性,删除<book genre="update李赞红" ISBN="2-3631-4">节点。

XmlNodeList xnl=xmlDoc.SelectSingleNode("bookstore").ChildNodes;

foreach(XmlNode xn in xnl)

{

XmlElement xe=(XmlElement)xn;

if(xe.GetAttribute("genre")=="fantasy")

{

xe.RemoveAttribute("genre");//删除genre属性

}

else if(xe.GetAttribute("genre")=="update李赞红")

{

xe.RemoveAll();//删除该节点的全部内容

}

}

xmlDoc.Save("bookstore.xml");

//====================

最后结果为:

<?xml version="1.0" encoding="gb2312"?>

<bookstore>

<book ISBN="2-3631-4">

<title>Oberon's Legacy</title>

<author>Corets, Eva</author>

<price>5.95</price>

</book>

<book>

</book>

</bookstore>

4、显示所有数据。

XmlNode xn=xmlDoc.SelectSingleNode("bookstore");

XmlNodeList xnl=xn.ChildNodes;

foreach(XmlNode xnf in xnl)

{

XmlElement xe=(XmlElement)xnf;

Console.WriteLine(xe.GetAttribute("genre"));//显示属性值

Console.WriteLine(xe.GetAttribute("ISBN"));

XmlNodeList xnf1=xe.ChildNodes;

foreach(XmlNode xn2 in xnf1)

{

Console.WriteLine(xn2.InnerText);//显示子节点点文本

}

}

以上的就是ASP.NET和C#对xml的基本使用方法。下面说一下xml和xsl,从抽象的来说,我个人觉得xml象是数据库,而xsl就象是过滤的。xsl中可以加入html等语法,也可以加入xml的语法等,可以列出需要的数据等。

现有一个xml文件,内容如下

<?xml version="1.0"?>

<?xml-stylesheet type="text/xsl" rel="external nofollow" href="test.xsl"?>

<NewDataSet>

<Table id="1">

<ProductID>1001</ProductID>

<CategoryID>1</CategoryID>

</Table>

<Table id="2">

<ProductID>1002</ProductID>

<CategoryID>2</CategoryID>

</Table>

</NewDataSet>

其中第2句是引用xsl,xsl内容如下

<?xml version="1.0"?>

<xsl:stylesheet xmlns:xsl="">

<xsl:template match="/">

<html>

<body>

<center>

<h2>the notepad</h2>

<table border="1">

<tr>

<td>id</td>

<td>name</td>

</tr>

<xsl:for-each select="NewDataSet/Table">

<tr>

<td><xsl:value-of select="ProductID"/></td>

<td><xsl:value-of select="ProductName"/></td>

</tr>

</xsl:for-each>

</table>

</center>

</body>

</html>

</xsl:template>

</xsl:stylesheet>

中间的for-each就是循环遍历节点,获取指定的select后的内容,下面的value-of就相当于sql中字段名。在使用xsl的时候,还可以查询某一个值,这样xsl就需要如下<xsl:value-of select="/students/student[@id='2']/ProductID"/>

<?xml version="1.0" encoding="gb2312"?>

<xsl:stylesheet xmlns:xsl="">

<xsl:template match="/">

<center><h1>id号是"2"的厂家的产品ID是:<xsl:value-of select="/NewDataSet/Table[@id='2']/ProductID"/></h1></center>

</xsl:template>

</xsl:stylesheet>

有些如果在Table下还有节点,要显示这个节点下的东西xsl就该如下

<?xml version="1.0"?>

<xsl:stylesheet xmlns:xsl="">

<xsl:template match="/">

<html>

<body>

<center>

<h2>the notepad</h2>

<table border="1">

<tr>

<td>随便写</td>

</tr>

<xsl:for-each select="NewDataSet/Table/xx/*">

<tr>

<td><xsl:value-of select="."/></td>

</tr>

</xsl:for-each>

</table>

</center>

</body>

</html>

</xsl:template>

</xsl:stylesheet>

html的下拉框的几个基本用法

<html>

<head>

<metahttp-equiv="Content-Type"content="text/html;charset=gbk">

<title>grid</title>

</head>

<body>

<inputtype="button"value="getSelect"onclick="getSelect()"/>

<inputtype="button"value="selectbtn"onclick="getSelAge()"/>

<div>

<selectname="selectAge"id="selectAge">

<optionvalue="1">18-21</option>

<optionvalue="2">22-25</option>

<optionvalue="3">26-29</option>

<optionvalue="4">30-35</option>

<optionvalue="5">Over35</option>

</select>

</div>

<p>

<inputtype="button"value="moreSelect"onclick="moreSelect()"/>

<div>

<div>多选须要添加multiple属性<br>

在多选中size属性能够初始化下拉框默认显示几个选项

</div>

<div>

<selectname="moreselAge"id="moreselAge"multiple="multiple">

<optionvalue="1">18-21</option>

<optionvalue="2">22-25</option>

<optionvalue="3">26-29</option>

<optionvalue="4">30-35</option>

<optionvalue="5">Over35</option>

<optionvalue="6">Over40</option>

<optionvalue="7">Over50</option>

</select>

</div>

</div>

<p></p>

<inputtype="button"value="addNewbtn"onclick="addNewSelections()"/>

<inputtype="button"value="deletebtn"onclick="deleteselections()"/>

<inputtype="button"value="deleAllbtn"onclick="deleteAllSelections()"/>

<div>selectName:<inputtype="text"id="txtName"/></div>

<div>selectValue:<inputtype="text"id="txtValue"/></div>

<div>

<selectname="moreselAge"id="addNew">

<optionvalue="1"selected>18-21</option>

<optionvalue="2">22-25</option>

<optionvalue="3">26-29</option>

<optionvalue="4">30-35</option>

<optionvalue="5">Over35</option>

<optionvalue="6">Over40</option>

<optionvalue="7">Over50</option>

</select>

</div>

<p>移动选项</p>

<p>

<table>

<trcollspan="2">

<td>

<div>

<selectname="moreselAge"id="move1"multiple="multiple"size="7">

<optionvalue="1">18-21sfiods</option>

<optionvalue="2">22-25sjdfd</option>

<optionvalue="3">26-29xxs</option>

<optionvalue="4">30-35vs</option>

<optionvalue="5">Over35dcff</option>

<optionvalue="6">Over40shhfsd</option>

<optionvalue="7">Over50sdefs</option>

<optionvalue="8">Over88www</option>

</select>

</div>

</td>

<tdwidth="100"align="center">

<inputtype="button"value=">"onclick="rightSingle()"/><br>

<inputtype="button"value=">>"onclick="rightAll()"/><br>

<inputtype="button"value="<"onclick="leftSingle()"/><br>

<inputtype="button"value="<<"onclick="leftAll()"/>

</td>

<td>

<div>

<selectname="moreselAge"id="move2"multiple="multiple"size="7">

<optionvalue="1">18-21</option>

<optionvalue="2">22-25</option>

<optionvalue="3">26-29</option>

<optionvalue="4">30-35</option>

<optionvalue="5">Over35</option>

<optionvalue="6">Over40</option>

<optionvalue="7">Over50</option>

<optionvalue="8">Over88</option>

</select>

</div>

</td>

<tr>

</table>

</body>

<scripttype="text/javascript">

//获得下拉列表对象

oListbox=document.getElementById("selectAge");

varListUtil=newObject();

varselectbtn=document.getElementById("selectbtn");

functiongetSelAge(){

//访问选项

alert(oListbox.options[1].firstChild.nodeValue);//显示的内容

alert(oListbox.options[1].getAttribute("value"));//相应的value

alert("获得它在集合中的位置=="+oListbox.options[2].index);//获得它在集合中的位置

alert("获得集合的元素个数长度=="+oListbox.options.length);//获得集合的元素个数长度

}

/*************************************************************************************************/

//获得选中选项

functiongetSelect(){

varindx=oListbox.selectedIndex;

alert("获得选中的选项的索引"+indx);

}

//多选下拉框

varmoreselAgeList=document.getElementById("moreselAge");

/*******************************************************************/

//入参下拉框对象

ListUtil.getSelectIndexes=function(oListbox){

vararrIndexes=newArray();

for(vari=0;i<oListbox.options.length;i++){

//假设该项被选中则把该项相应的索引加入到数组中

if(oListbox.options[i].selected){

arrIndexes.push(i);

}

}

returnarrIndexes;//返回选中的选项索引

}

/***************************************************************/

//多选

functionmoreSelect(){

vararrIndexes=ListUtil.getSelectIndexes(moreselAgeList);

alert("选中的数组length="+arrIndexes.length+"选中的选项索引为:"+arrIndexes);

}

/************************加入新选项***************************************************************/

//

varaddNewLisbox=document.getElementById("addNew");//获得下拉框对象

varotxtName=document.getElementById("txtName");//name文本框

varotxtValue=document.getElementById("txtValue");//value文本框

//加入方法

ListUtil.addOptions=function(oListbox,sName,sValue){

vararryV=newArray();

//标记输入的值能否够加入

varisAdd=false;

//推断是否有反复的值

for(vari=0;i<oListbox.options.length;i++){

varsv=oListbox.options[i].getAttribute("value");

if(sv==sValue){

alert("不能加入反复的value");

return;

}else{

isAdd=true;

}

}

if(isAdd||oListbox.options.length==0){

//以下使用dom方法创建节点

varoOption=document.createElement("option");//创建option元素

oOption.appendChild(document.createTextNode(sName));

//由于选项的值不是必须的,所以假设传入了值则加入进来

if(arguments.length==3){

oOption.setAttribute("value",sValue);

}

oListbox.appendChild(oOption);//把选项加入进列表框

alert("加入成功!!");

}//endif(isAdd)

}

//加入button的点击事件方法

functionaddNewSelections(){

vartxtname=otxtName.value;

vartxtvalue=otxtValue.value;

if(txtname!=""&&txtvalue!=""){

ListUtil.addOptions(addNewLisbox,txtname,txtvalue);//加入新项

otxtName.value="";

otxtValue.value="";

}else{

alert("请输入要加入的值和name");

return;

}

}

/*******************删除选中选项****************************************************************/

//传入下拉框对象和(索引)

ListUtil.deleteOptons=function(oListbox){

varselIndex=oListbox.selectedIndex;

if(oListbox.options.length==0){

alert("列表中无元素可删除");

return;

}

oListbox.remove(selIndex);//删除选中的选项

}

//删除button点击事件

functiondeleteselections(){

ListUtil.deleteOptons(addNewLisbox);

}

/**********删除全部***********************************************************************/

ListUtil.deletsAllOptions=function(oListbox){

if(oListbox.options.length!=0){

for(vari=oListbox.options.length-1;i>=0;i--){//倒着删除是由于

oListbox.remove(i);

}

}else{

alert("该列表为空!");

}

}

functiondeleteAllSelections(){

ListUtil.deletsAllOptions(addNewLisbox);

}

/*******移动选项***************************************************************************************/

//获得下拉框

varmove1Listbox=document.getElementById("move1");//左边下拉框

varmove2Listbox=document.getElementById("move2");//右边下拉框

//移动一个或多个选中的选项

ListUtil.move=function(oListboxFrom,oListboxTo){

//varidx1=oListboxFrom.selectedIndex;

vararrIndexes=ListUtil.getSelectIndexes(oListboxFrom);

varoOption;

if(arrIndexes.length==0){

alert("请选择至少一个选项!");

return;

}else{

for(vari=oListboxFrom.options.length-1;i>=0;i--){

oOption=oListboxFrom.options[i];

if(oOption.selected&&oOption!=null){

oListboxTo.appendChild(oOption);

}

}

}

}

//向右移一个元素

functionrightSingle(){

ListUtil.move(move1Listbox,move2Listbox);

};

//向左移一个元素

functionleftSingle(){

ListUtil.move(move2Listbox,move1Listbox);

}

ListUtil.moveAll=function(oListboxFrom,oListboxTo){

for(vari=oListboxFrom.options.length-1;i>=0;i--){

oOption=oListboxFrom.options[i];

//alert(oOption);

oListboxTo.appendChild(oOption);

}

}

//向右移全部选项

functionrightAll(){

ListUtil.moveAll(move1Listbox,move2Listbox);

}

//向左移全部选项

functionleftAll(){

ListUtil.moveAll(move2Listbox,move1Listbox);

}

</script>

</html>

关于setattribute用法,setattribute的两个参数的介绍到此结束,希望对大家有所帮助。

php文件打开方式?php文件java典型案例程序代码(java基础案例教程第二版答案)