Javascript dynamic control server control example_javascript skills
Recently, many pages need to load some drop-down list boxes for users to choose. Originally, they were all loaded on the server side. Finally, due to business logic considerations, some functions of DropDownList need to be implemented on the client side. Now the drop-down list function feels much better to use than putting it all on the server side.
Specific method:
Put a DropDownList control in the page and add an item to analyze the HTML code it generates. This way, when using js for dynamic control, it will be very clear. The test code is as follows:
<asp:DropDownList ID="DropDownList1" runat="server"> <asp:ListItem>1</asp:ListItem> </asp:DropDownList>
View in the browser and analyze the Html: The following is the HTML code generated by the DropDownList control. It’s not the same as the normal selection
There is a difference. Then you can dynamically fill, delete, select and other controls through js.
<select name="DropDownList1" id="DropDownList1"> <option value="1">1</option> </select>
You can delete
<input id="Button1" type="button" value="添加Option" onclick="addOption()" /> <input id="Button2" type="button" value="全部删除Option" onclick="delOption()" />
Adding and removing functions looks like this:
function addOption(){ var ddlObj = document.getElementById("DropDownList1");//获取对象 if(ddlObj.length>0) delOption();//先删除所有的,之后在添加 var optText = new Array("founder","china","beijing"); var optValue = new Array("0","1","2"); var oOption = null; for(var i=0;i<optText.length;i++){ oOption = new Option(optText[i],optValue[i]); ddlObj.options.add(oOption); } } function delOption(){ var ddlObj = document.getElementById("DropDownList1");//获取对象 for(var i=ddlObj.length-1;i>=0;i--){ ddlObj.remove(i);//firefox不支持ddlCurSelectKey.options.remove(),IE两种均支持 } }
Viewed in a browser, you can easily create select drop-down options, and since these are client-side generated, they are more efficient than server-side
Code for side work. But at this time, if you want to use DropDownList1.SelectedValue to get the options selected by the user, then you will have to
An error occurred. This is because the DropDownList is dynamically added by JS, therefore, its items do not belong to ViewState and are not maintained,
That means we can't handle it on the server side. In order to solve this problem, two methods can be used: 1. Hidden control saving
User option method; 2. Request.Form method. (See msdn Taste of Ajax)
1. We add a Hidden control to the page and use it to save the information about the DropDownList option changes, so that the user’s sense of selection
After receiving the information of interest, we can obtain the information on the server side and process it to reasonably realize the division of labor between customers and service.
Add an onchange event to the DropDownList control. At this time, its html code is as follows:
<asp:DropDownList ID="DropDownList1" runat="server" onchange="ResvItem()"> </asp:DropDownList>
Onchange event is as follows. This event mainly saves the value selected by the user:
function ResvItem(){ var objDdl = document.getElementById("DropDownList1"); document.getElementById("HiddenField1").value = objDdl.options[objDdl.selectedIndex].value; }
After this, we use an asp:button control to test the results:
protected void Button1_Click(object sender, EventArgs e) { Response.Write(HiddenField1.Value); }
At this point, all the work has been completed, but there is still a problem. The change event of DropDownList can only be used when the user changes the drop-down selection
It will only be triggered whenis selected. Therefore, when the user submits with the default options, they get a null value. So we can fill in the option, that is,
hidden initialization. Add a line of code to the addOption event as follows:
function addOption(){ var ddlObj = document.getElementById("DropDownList1");//获取对象 if(ddlObj.length>0) delOption();//先删除所有的,之后在添加 var optText = new Array("founder","china","beijing"); var optValue = new Array("0","1","2"); var oOption = null; for(var i=0;i<optText.length;i++){ oOption = new Option(optText[i],optValue[i]); ddlObj.options.add(oOption); } document.getElementById("HiddenField1").value = optValue[0]; }
However, the above red part is not successful in ADD under TT browser. I haven’t tried it in other browsers. Here is another way to write it:
function GetDeptList() { var ddlCityType = document.getElementById("ddlCityType"); var ddlPosition = document.getElementById("ddlPosition"); var v = ddlCityType.options[ddlCityType.selectedIndex]; //alert(v.value); var DeptList=Guest_UserRegister.GetDeptList(v.value).value; var deptList=new Array(); deptList=DeptList.split(';'); for(var i=0;i<deptList.length;i++) { if(deptList[i]!="") { var dept=deptList[i].split(','); var opt = document.createElement("option"); opt.innerHTML = dept[1]; opt.value = dept[0]; ddlPosition.insertBefore(opt, ddlPosition.firstChild); } } } function DelOption() { var ddluserSchool = document.getElementById("ddluserSchool"); var num=ddluserSchool.length; while(num>0) { for(var j=0;j<num;j++) { ddluserSchool.remove(j); } num=ddluserSchool.length; } } function GetSchoolList() { DelOption(); var ddlProvince = document.getElementById("ddlProvince"); var ddluserSchool = document.getElementById("ddluserSchool"); var v = ddlProvince.options[ddlProvince.selectedIndex]; var DeptList=Guest_UserRegister.GetSchoolList(v.value).value; var deptList=new Array(); deptList=DeptList.split(';'); for(var i=0;i<deptList.length;i++) { if(deptList[i]!="") { var dept=deptList[i].split(','); var opt = document.createElement("option"); opt.innerHTML = dept[1]; opt.value = dept[0]; ddluserSchool.insertBefore(opt, ddluserSchool.firstChild); } } }

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

Frequently Asked Questions and Solutions for Front-end Thermal Paper Ticket Printing In Front-end Development, Ticket Printing is a common requirement. However, many developers are implementing...

JavaScript is the cornerstone of modern web development, and its main functions include event-driven programming, dynamic content generation and asynchronous programming. 1) Event-driven programming allows web pages to change dynamically according to user operations. 2) Dynamic content generation allows page content to be adjusted according to conditions. 3) Asynchronous programming ensures that the user interface is not blocked. JavaScript is widely used in web interaction, single-page application and server-side development, greatly improving the flexibility of user experience and cross-platform development.

There is no absolute salary for Python and JavaScript developers, depending on skills and industry needs. 1. Python may be paid more in data science and machine learning. 2. JavaScript has great demand in front-end and full-stack development, and its salary is also considerable. 3. Influencing factors include experience, geographical location, company size and specific skills.

Learning JavaScript is not difficult, but it is challenging. 1) Understand basic concepts such as variables, data types, functions, etc. 2) Master asynchronous programming and implement it through event loops. 3) Use DOM operations and Promise to handle asynchronous requests. 4) Avoid common mistakes and use debugging techniques. 5) Optimize performance and follow best practices.

How to merge array elements with the same ID into one object in JavaScript? When processing data, we often encounter the need to have the same ID...

Discussion on the realization of parallax scrolling and element animation effects in this article will explore how to achieve similar to Shiseido official website (https://www.shiseido.co.jp/sb/wonderland/)...

The latest trends in JavaScript include the rise of TypeScript, the popularity of modern frameworks and libraries, and the application of WebAssembly. Future prospects cover more powerful type systems, the development of server-side JavaScript, the expansion of artificial intelligence and machine learning, and the potential of IoT and edge computing.

In-depth discussion of the root causes of the difference in console.log output. This article will analyze the differences in the output results of console.log function in a piece of code and explain the reasons behind it. �...
