select.java
来自「jakarta-taglibs」· Java 代码 · 共 327 行
JAVA
327 行
/*
* Copyright 1999,2004 The Apache Software Foundation.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.apache.taglibs.input;
import java.util.*;
import javax.servlet.*;
import javax.servlet.jsp.*;
import javax.servlet.jsp.tagext.*;
/**
*
* This class implements the <input:select> tag, which presents a
* <select> form element.
*
* @version 0.90
* @author Shawn Bayern
* @author Lance Lavandowska
*/
public class Select extends TagSupport {
private String name; // name of the select element
private String dVal; // default value if none is found
private String[] dValArray; // our multiple default values
private Map attributes; // attributes of the <select> element
private Map options; // what are our options? :)
private String attributesText; // attributes of the <input> element as text
private String beanId; // bean id to get default values from
private boolean multiple; // select multiple
private String size; // select size
private List optionLabels; // a list of option labels
private List optionValues; // a list of option values
private HashMap chosen; // chosen options (created in doStartTag)
public int doStartTag() throws JspException {
try {
// sanity check
if (name == null || name.equals(""))
throw new JspTagException("invalid null or empty 'name'");
// Store beanId in a local variable as we change it
String beanId = this.beanId;
// Get default beanId
if ( beanId == null ) {
beanId = Util.defaultFormBeanId( this );
}
else if ( beanId.length() == 0 ) {
// An empty beanId means, do not use any bean - not even default
beanId = null;
}
// get what we need from the page
ServletRequest req = pageContext.getRequest();
JspWriter out = pageContext.getOut();
// start building up the tag
out.print("<select name=\"" + Util.quote(name) + "\" ");
// include any attributes we've got here
Util.printAttributes(out, attributes);
if ( attributesText != null ) {
out.print( attributesText + " " );
}
if ( multiple ) {
out.print( "multiple=\"true\" " );
}
if ( size != null ) {
out.print( "size=\"" + Util.quote(size) + "\" " );
}
// end the starting tag
out.println(">");
/*
* Print out our options, selecting one or more if appropriate.
* If there are multiple selections but the page doesn't call
* for a <select> that accepts them, ignore the selections.
* This is preferable to throwing a JspException because the
* (end) user can control input, and we don't want the user
* causing exceptions in our application.
*/
String[] selected;
// Use selected from the bean, if available
String [] beanValues = ( beanId != null ? Util.beanPropertyValues(
pageContext.findAttribute( beanId ), name ) : null );
if ( beanValues != null ) {
selected = beanValues;
}
else {
// get the current selection from the request
selected = req.getParameterValues(name);
if ( selected == null ) {
// Use defaults
if ( dValArray != null && dVal != null ) {
selected = new String[ dValArray.length + 1 ];
selected[0] = dVal;
System.arraycopy( dValArray, 0, selected, 1, dValArray.length );
}
else if ( dValArray != null ) {
selected = dValArray;
}
else if ( dVal != null ) {
selected = new String[] { dVal };
}
}
}
if (selected != null && selected.length > 1 &&
((attributes == null || !attributes.containsKey("multiple")) && !multiple))
selected = null;
// load up the selected values into a hash table for faster access
// and for option tags to access
chosen = new HashMap();
if (selected != null) {
for (int i = 0; i < selected.length; i++) {
if ( selected[i] != null ) {
chosen.put(selected[i], null);
}
}
}
// actually print the <option> tags
if ( optionLabels != null ) {
// Print out using the optionLabels
int n = optionLabels.size();
for ( int i = 0; i < n; i++ ) {
Object oKey = optionLabels.get( i );
Object oVal = ( options != null ? options.get(oKey)
: ( optionValues != null ? optionValues.get( i ) : oKey ) );
outputOption( out, oKey, oVal );
}
}
else if (options != null) {
Iterator i = options.keySet().iterator();
while (i.hasNext()) {
Object oKey = i.next();
Object oVal = options.get(oKey);
outputOption( out, oKey, oVal );
}
}
} catch (Exception ex) {
throw new JspTagException(ex.getMessage());
}
return EVAL_BODY_INCLUDE;
}
private void outputOption( JspWriter out, Object oKey, Object oVal ) throws java.io.IOException {
String key = oKey.toString();
/*
* Convert the value to a String if it is not already.
*/
String value = ( oVal != null ? oVal.toString() : null );
if (value == null)
value = key; // use key if value is null
out.print("<option");
if (!value.equals(key))
out.print(" value=\"" + Util.quote(value) + "\"");
/*
* This may look confusing: we match the VALUE of
* this option pair with the KEY of the 'chosen' Map
* (We want to match <option>s on values, not keys.)
*/
if (chosen.containsKey(value))
out.print(" selected=\"true\"");
out.print(">");
out.print(Util.quote(key));
out.println("</option>");
}
public int doEndTag() throws JspException {
try {
JspWriter out = pageContext.getOut();
out.print( "</select>" );
} catch (Exception ex) {
throw new JspTagException(ex.getMessage());
}
return EVAL_PAGE;
}
public void setName(String x) {
name = x;
}
public void setAttributes(Map x) {
attributes = x;
}
public void setAttributesText( String x ) {
attributesText = x;
}
public void setBean( String x ) {
beanId = x;
}
public void setMultiple( boolean x ) {
multiple = x;
}
public void setSize( String x ) {
size = x;
}
public void setDefault(String x) {
dVal = x;
}
public void setDefaults(String[] x) {
dValArray = x;
}
public void setDefaults(Map x) {
dValArray = new String[ x.size() ];
Iterator it = x.keySet().iterator();
int i = 0;
while ( it.hasNext() ) {
dValArray[i++] = it.next().toString();
}
}
public void setDefaults(Collection c) {
dValArray = new String[ c.size() ];
Iterator it = c.iterator();
int i = 0;
while ( it.hasNext() ) {
dValArray[i++] = it.next().toString();
}
}
public void setOptions(Map x) {
options = x;
}
public void setOptionLabels(List x) {
optionLabels = x;
}
public void setOptionValues(List x) {
optionValues = x;
}
public HashMap getChosen() {
return chosen;
}
/** Getter for property name.
* @return Value of property name.
*/
public String getName() { return name; }
/** Getter for property default.
* @return Value of property default.
*/
public String getDefault() { return dVal; }
/** Getter for property bean.
* @return Value of property bean.
*/
public String getBean() { return beanId; }
/** Getter for property attributesText.
* @return Value of property attributesText.
*/
public String getAttributesText() { return attributesText; }
/** Getter for property attributes.
* @return Value of property attributes.
*/
public Map getAttributes() { return attributes; }
/** Getter for property defaults.
* @return Value of property defaults.
*/
public String[] getDefaults() { return dValArray; }
/** Getter for property multiple.
* @return Value of property multiple.
*/
public boolean isMultiple() { return multiple; }
/** Getter for property optionLabels.
* @return Value of property optionLabels.
*/
public List getOptionLabels() { return optionLabels; }
/** Getter for property optionValues.
* @return Value of property optionValues.
*/
public List getOptionValues() { return optionValues; }
/** Getter for property options.
* @return Value of property options.
*/
public Map getOptions() { return options; }
/** Getter for property size.
* @return Value of property size.
*/
public String getSize() { return size; }
}
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?