⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 dynamicoptionlist.js

📁 jsp程序开发系统
💻 JS
字号:
// two functions to allow the change of visibility optionsfunction visno(id) {	e=document.getElementById(id).style;	e.display='none';}function visyes(id) {	e=document.getElementById(id).style;	e.display='';}// Pass in the name of the element, then the names of the lists it depends onfunction DynamicOptionList() {	if (arguments.length < 2) { alert("Not enough arguments in DynamicOptionList()"); }	// Name of the list containing dynamic values	this.target = arguments[0];	// Set the lists that this dynamic list depends on	this.dependencies = new Array();	for (var i=1; i<arguments.length; i++) {		this.dependencies[this.dependencies.length] = arguments[i];	}	// The form this list belongs to	this.form = null;	// Place-holder for currently-selected values of dependent select lists	this.dependentValues = new Object();	// Hold default values to be selected for conditions	this.defaultValues = new Object();	// Storage for the dynamic values	this.options = new Object();	// Delimiter between dependent values	this.delimiter = "|";	// Logest string currently a potential options (for Netscape)	this.longestString = "";	// The total number of options that might be displayed, to build dummy options (for Netscape)	this.numberOfOptions = 0;	// Method mappings	this.addOptions = DynamicOptionList_addOptions;	this.populate = DynamicOptionList_populate;	this.setDelimiter = DynamicOptionList_setDelimiter;	this.setDefaultOption = DynamicOptionList_setDefaultOption;	this.printOptions = DynamicOptionList_printOptions;	this.init = DynamicOptionList_init;}// Set the delimiter to something other than | when defining condition valuesfunction DynamicOptionList_setDelimiter(val) {	this.delimiter = val;}// Set the default option to be selected when the list is paintedfunction DynamicOptionList_setDefaultOption(condition, val) {	this.defaultValues[condition] = val;}// Init call to map the form to the object and populate itfunction DynamicOptionList_init(theform) {	this.form = theform;	this.populate();}// Add options to the list.// Pass the condition string, then the list of text/value pairs that populate the list	function DynamicOptionList_addOptions(dependentValue) {	if (typeof this.options[dependentValue] != "object") { 		this.options[dependentValue] = new Array(); 	}	for (var i=1; i<arguments.length; i+=2) {		// Keep track of the longest potential string, to draw the option list		if (arguments[i].length > this.longestString.length) {			this.longestString = arguments[i];		}		this.numberOfOptions++;		this.options[dependentValue][this.options[dependentValue].length] = arguments[i];		this.options[dependentValue][this.options[dependentValue].length] = arguments[i+1];	}}// Print dummy options so Netscape behaves nicelyfunction DynamicOptionList_printOptions() {	// Only need to write out "dummy" options for Netscape    if ((navigator.appName == 'Netscape') && (parseInt(navigator.appVersion) <= 4)){		var ret = "";		for (var i=0; i<this.numberOfOptions; i++) { 			ret += "<OPTION>";			}		ret += "<OPTION>"		for (var i=0; i<this.longestString.length; i++) {			ret += "_";			}		document.writeln(ret);		}	}// Populate the listfunction DynamicOptionList_populate() {	var theform = this.form;	var i,j,obj,obj2;	// Get the current value(s) of all select lists this list depends on	this.dependentValues = new Object;	var dependentValuesInitialized = false;	for (i=0; i<this.dependencies.length;i++) {		var sel = theform[this.dependencies[i]];		var selName = sel.name;		// If this is the first dependent list, just fill in the dependentValues		if (!dependentValuesInitialized) {			dependentValuesInitialized = true;			for (j=0; j<sel.options.length; j++) {				if (sel.options[j].selected) {					this.dependentValues[sel.options[j].value] = true;					}				}			}		// Otherwise, add new options for every existing option		else {			var tmpList = new Object();			var newList = new Object();			for (j=0; j<sel.options.length; j++) {				if (sel.options[j].selected) {					tmpList[sel.options[j].value] = true;					}				}			for (obj in this.dependentValues) {				for (obj2 in tmpList) {					newList[obj + this.delimiter + obj2] = true;					}				}			this.dependentValues = newList;			}		}	var targetSel = theform[this.target];			// Store the currently-selected values of the target list to maintain them (in case of multiple select lists)	var targetSelected = new Object();	for (i=0; i<targetSel.options.length; i++) {		if (targetSel.options[i].selected) {			targetSelected[targetSel.options[i].value] = true;			}		}	targetSel.options.length = 0; // Clear all target options			for (i in this.dependentValues) {		if (typeof this.options[i] == "object") {				visyes(targetSel.id); // added by chris to make visible			var o = this.options[i];			for (j=0; j<o.length; j+=2) {				var text = o[j];				var val = o[j+1];				targetSel.options[targetSel.options.length] = new Option(text, val, false, false);				if (this.defaultValues[i] == val) {					targetSelected[val] = true;					}				}			} else {				visno(targetSel.id); // added by chris to hide			}		}	targetSel.selectedIndex=-1;		// Select the options that were selected before	for (i=0; i<targetSel.options.length; i++) {		if (targetSelected[targetSel.options[i].value] != null && targetSelected[targetSel.options[i].value]==true) {			targetSel.options[i].selected = true;			}		}	}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -