项目中经常用到Select标签,用封装好的方法获取option,可以避免冗赘的代码;

1.JSP--标签

<select class="width_md" name="queryProjectSupType" id="queryProjectSupType" title="项目类型-大类"></select>

2.JS1--实例化option

<script type="text/javascript">
$().ready(function(){
SELECT_LIST.getProjectSupType("queryProjectSupType", "${pd.queryProjectSupType}");
    })
</script>

3.JS2--数据封装

var SELECT_LIST = {
getProjectSupType: function(targetId,selectValue){
var url = 'dictionary/list/condition';
var dicType = {};
dicType.url = url;//ajax的url
dicType.targetId = targetId;//即将实例化的select标签的id
dicType.keyValue = "dicName";//从数据库获取的Json数据,将key为"dicName"的value赋值给option的value属性
dicType.keyName = "dicName";//从数据库获取的Json数据,将key为"dicName"的value赋值给option的text属性
dicType.condition = {codeId:8};//这是从传给数据库的数据筛选条件,因需求而异
dicType.firstOption = "<option value=''>请选择分类</option>";//默认的第一个option标签的text属性
dicType.selectedValue = selectValue;//标签实例化后,value等于selectValue的option,将默认选中
ajaxGenerateSelect(dicType);//ajax获取数据,生成option数据
}
}

3.JS3--1.ajax获取数据,2.js生成option标签,并放入Select标签

function ajaxGenerateSelect(selectObject){
var url = selectObject.url;
var method = selectObject.method ? selectObject.method : "POST";
var keyValue = selectObject.keyValue ? selectObject.keyValue : "id";
var keyName = selectObject.keyName ? selectObject.keyName : "name";
var selectedValue = selectObject.selectedValue ? selectObject.selectedValue : null;
var targetId = selectObject.targetId;
var condition = selectObject.condition ? selectObject.condition : {};
var afterHandle = selectObject.afterHandle;
var formatter = selectObject.formatter;
var firstOption = selectObject.firstOption;
var ajaxObject = {};
ajaxObject.url = url;
ajaxObject.method = method;
ajaxObject.data = JSON.stringify(condition);
ajaxObject.success = function(result){
var data = result.data;
var html = "";
if(firstOption){
html = firstOption;
}
for(var i=0;i<data.length;i++){
var selected = "";
var dataItem = data[i];
if(selectedValue == dataItem[keyValue]){
selected = "selected";
}
var option = "<option value='#(value)' #(selected)>#(name)</option>";
var nameValue = dataItem[keyName];
if(formatter){
nameValue = formatter(dataItem);
}
option = option.replace("#(value)", dataItem[keyValue]).
replace("#(name)",nameValue).replace("#(selected)", selected);
html += option;
}
$("#" + targetId).html('').append(html);
if(afterHandle){
afterHandle();
}
}; ajaxMethod(ajaxObject);
}

项目总结09:select标签下封装option标签的更多相关文章

  1. qt 删除xml某个标签下所有子标签

    代码如下: QDomNodeList listFlowChart= doc.elementsByTagName("device"); QDomElement flowChart = ...

  2. jquery 条件搜索某个标签下的子标签

    $("li[name='"+name+"']").find("a[value='" + value + "']").pa ...

  3. jquery怎么获取当前标签下的子标签

    1.var num1=$("ul > a:eq(0)").attr("ID");2.var num2=$("ul").children ...

  4. select下拉框的探索(<option></option>标签中能嵌套使用其它标签吗)

      select标签大家应该经常用到,有个问题可能没怎么注意过, select标签里面的option标签可以嵌套其它标签吗,比如i,span标签等? 经本人测试,答案是:可以嵌套其它标签,但审查元素会 ...

  5. html select与option标签

    1.select 元素 select 元素可创建单选或多选菜单.<select> 元素中的 <option> 标签用于定义列表中的可用选项 常用属性如下: autofocus: ...

  6. 来吧,HTML5之基础标签(下)

    <dialog> 标签 定义对话框或窗口. <dialog> 标签是 HTML 5 的新标签.目前只有 Chrome 和 Safari 6 支持 <dialog>  ...

  7. HTML常用标签(下)

    HTML常用标签(下) 1. 表格标签 1.1 语法 <table> <!--table定义表格--> <tr> <!--tr定义表格中的行--> &l ...

  8. IE6 P标签下DIV无法inline-block

    IE6 P标签下的DIV标签无法inline-block,使其触发了hasLayout属性再用csshack 使其inline还是不行,始终要换行 解决:把div标签替换成非div标签,比如span等 ...

  9. 帝国cms灵动标签下常用标签

    这里简单整理下灵动标签下的常用标签 标题名称:<?=$bqr['title']?>  <?=esub($bqr[title],22)?> 限制字符22个 标题链接:<?= ...

随机推荐

  1. ThreadLoacl 小记

    参考地址: https://www.cnblogs.com/dolphin0520/p/3920407.html ThreadLoacl 本地线程变量 为线程创建一个副本, 一个内部类ThreadLo ...

  2. gitlab入门

    目录 git下载 注册ssh git客户端及图形化工具tortoisegit下载: git客户端安装: https://git-scm.com/download   (git客户端 此种需要命令行执行 ...

  3. ORACLE问题定位基本方法

    在使用ORACLE过程中经常会碰到启动或者访问失败的问题.碰到这些问题该如何解决? 1.仔细阅读报错提示信息,不要扫一眼感觉似曾相识,凭经验就开始上手解决.因为相同的现象可能是不同的原因引发的. 2. ...

  4. JAVAWEB 一一ibatis(框架)

    ,升级版是mybatis,在配置文件里写sql语句对字段进行CURD) jar包 sqlMapConfig <?xml version="1.0" encoding=&quo ...

  5. Oracle 未能加载文件或程序集Oracle.DataAccess

    原文地址;https://www.cnblogs.com/xuekai-to-sharp/p/3586071.html 关键是引用DLL:Oracle.DataAccess.dll DLL文件的路径: ...

  6. js基础-运算符

    100 * "20" 字符串转数字 5 * "ss"  NAN "ss" 转数字返回NAN 任何数字与NAN +-*/ 都返回NAN 5/N ...

  7. JAVA语言 第二周

    放假第二周了,时间真快! 上一周配置好了环境变量,这一周就可以做一些测试了.对不同的内容分类进行了测试,包括写入.输出.变量·······还有很多.对于开学的试卷,在第一部分做的还行,第二部分就没什么 ...

  8. 关于小程序 scroll-view 左右横向滑动没有效果(无法滑动)问题

    https://www.cnblogs.com/miu-key/p/7606024.html

  9. CentOS7下解决yum install mysql-server没有可用包

    # wget http://repo.mysql.com/mysql-community-release-el7-5.noarch.rpm --  http://repo.mysql.com/mysq ...

  10. Java中Properties集合总结

    一:定义 表示一个持久的集,可以存在流中或者从流中加载.用来读取Java的配置文件,在Java中为.properties为后缀名的文本文件. 二:特点 是 Hashtable子类,map集合方法都可以 ...