📄 form.js
字号:
/* Copyright (c) 2004-2006, The Dojo Foundation All Rights Reserved. Licensed under the Academic Free License version 2.1 or above OR the modified BSD license. For more information on Dojo licensing, see: http://dojotoolkit.org/community/licensing.shtml*/dojo.provide("dojo.widget.Form");dojo.require("dojo.widget.*");dojo.require("dojo.widget.HtmlWidget");dojo.widget.defineWidget("dojo.widget.Form", dojo.widget.HtmlWidget, { isContainer: true, templateString: "<form dojoAttachPoint='containerNode' dojoAttachEvent='onSubmit:onSubmit'></form>", formElements: [], postCreate: function(args,frag){ for (var key in args) { if (key == "dojotype") continue; var attr= document.createAttribute(key); attr.nodeValue=args[key]; this.containerNode.setAttributeNode(attr); } }, _createFormElements: function() { if(dojo.render.html.safari) { // bug in safari (not registering form-elements) var elems = ["INPUT", "SELECT", "TEXTAREA"]; for (var k=0; k < elems.length; k++) { var list = this.containerNode.getElementsByTagName(elems[k]); for (var j=0,len2=list.length; j<len2; j++) { this.formElements.push(list[j]); } } // fixed in safari nightly } else { this.formElements=this.containerNode.elements; } }, onSubmit: function(e) { e.preventDefault(); }, submit: function() { this.containerNode.submit(); }, _getFormElement: function(name) { for(var i=0, len=this.formElements.length; i<len; i++) { var element = this.formElements[i]; if (element.name == name) { return element; } // if } // for return null; }, _getObject: function(obj, searchString) { var namePath = []; namePath=searchString.split("."); var myObj=obj; var name=namePath[namePath.length-1]; for(var j=0, len=namePath.length;j<len;++j) { var p=namePath[j]; if (typeof(myObj[p]) == "undefined") { myObj[p]={}; } myObj=myObj[p]; } return myObj; }, _setToContainers: function (obj, widget) { for(var i=0, len=widget.children.length; i<len; ++i) { if (widget.children[i].widgetType == "Repeater") { var rIndex=widget.children[i].pattern; var rIndexPos=rIndex.indexOf("%{index}"); rIndex=rIndex.substr(0,rIndexPos-1); var myObj = this._getObject(obj, rIndex); if (typeof(myObj) == "object" && typeof(myObj.length) == "undefined") { myObj=[]; } var rowCount = widget.children[i].getRowCount(); if (myObj.length > rowCount) { for (var j=rowCount, len2=myObj.length; j<len2; j++) { widget.children[i].addRow(); } } else if (myObj.length < rowCount) { for (var j=rowCount, len2=myObj.length; j>len2; j--) { widget.children[i].deleteRow(0); } } for (var j=0, len2=myObj.length;j<len2; ++j) { for (var key in myObj[j]) { var prefix = dojo.string.substituteParams(widget.children[i].index, {"index": "" + j}); this._getFormElement(prefix+"."+key).value=myObj[j][key]; } } } if (widget.children[i].isContainer) { this._setToContainers (obj, widget.children[i]); continue; } switch(widget.children[i].widgetType) { case "Checkbox": continue; break; case "DropdownDatePicker": if(widget.children[i].valueNode.value == "") { widget.children[i].inputNode.value=""; widget.children[i].datePicker.storedDate=""; } else { widget.children[i].datePicker.setDate(widget.children[i].valueNode.value); //widget.children[i].datePicker.date=dojo.widget.DatePicker.util.fromRfcDate(widget.children[i].valueNode.value); widget.children[i].onSetDate(); } break; case "Select": //widget.children[i].setValue(myObj[name]); continue; break; case "ComboBox": //widget.children[i].setSelectedValue(myObj[name]); continue; break; default: break; } } }, setValues: function(obj) { this._createFormElements(); for(var i=0, len=this.formElements.length; i<len; i++) { var element = this.formElements[i]; if (element.name == '') {continue}; var namePath = new Array(); namePath=element.name.split("."); var myObj=obj; var name=namePath[namePath.length-1]; for(var j=1,len2=namePath.length;j<len2;++j) { var p=namePath[j - 1]; if(typeof(myObj[p]) == "undefined") { myObj=undefined; break; //myObj[p]={} }; myObj=myObj[p]; } if (typeof(myObj) == "undefined") { continue; } var type=element.type; if (type == "hidden" || type == "text" || type == "textarea" || type == "password") { type = "text"; } switch(type) { case "checkbox": this.formElements[i].checked=false; if (typeof(myObj[name]) == 'undefined') continue; for (var j=0,len2=myObj[name].length; j<len2; ++j) { if(element.value == myObj[name][j]) { element.checked=true; } } break; case "radio": this.formElements[i].checked=false; if (typeof(myObj[name]) == 'undefined') {continue}; if (myObj[name] == this.formElements[i].value) { this.formElements[i].checked=true; } break; case "select-one": this.formElements[i].selectedIndex="0"; for (var j=0,len2=element.options.length; j<len2; ++j) { if (element.options[j].value == myObj[name]) { element.options[j].selected=true; } else { //element.options[j].selected=false; } } break; case "text": var value=""; if (typeof(myObj[name]) == 'string') { value = myObj[name]; } this.formElements[i].value=value; break; default: //dojo.debug("Not supported type ("+type+")"); break; } } this._setToContainers(obj,this); }, getValues: function() { this._createFormElements(); var obj = { }; for(var i=0,len=this.formElements.length; i<len; i++) { // FIXME: would be better to give it an attachPoint: var elm = this.formElements[i]; var namePath = []; if (elm.name == '') { continue;} namePath=elm.name.split("."); var myObj=obj; var name=namePath[namePath.length-1]; for(var j=1,len2=namePath.length;j<len2;++j) { var nameIndex = null; var p=namePath[j - 1]; var nameA=p.split("["); if (nameA.length > 1) { if(typeof(myObj[nameA[0]]) == "undefined") { myObj[nameA[0]]=[ ]; } // if nameIndex=parseInt(nameA[1]); if(typeof(myObj[nameA[0]][nameIndex]) == "undefined") { myObj[nameA[0]][nameIndex]={}; } } else if(typeof(myObj[nameA[0]]) == "undefined") { myObj[nameA[0]]={} } // if if (nameA.length == 1) { myObj=myObj[nameA[0]]; } else { myObj=myObj[nameA[0]][nameIndex]; } // if } // for if ((elm.type != "checkbox" && elm.type != "radio") || (elm.type=="radio" && elm.checked)) { if(name == name.split("[")[0]) { myObj[name]=elm.value; } else { // can not set value when there is no name } } else if (elm.type == "checkbox" && elm.checked) { if(typeof(myObj[name]) == 'undefined') { myObj[name]=[ ]; } myObj[name].push(elm.value); } // if name=undefined; } // for return obj; }});
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -