温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

关于自由流功能开发过程中前端的一些问题汇总

发布时间:2020-06-12 04:17:03 来源:网络 阅读:684 作者:gaochaojs 栏目:web开发

  之前一直从事C/S的开发,关于B/S用到的一些技术是不熟悉的,现在在逐步学习中,希望通过及时总结加强理解和记忆。目前开发的系统使用的主要是JQueryStuts2Spring

关于自由流后端及Jbpm的实现我会在另一篇博文中介绍,这里只介绍我在前端使用htmlJQuery中遇到的问题以及对我来说不常使用的知识点。

1.关于Map以及JsonObject

在后端使用Map数据结构将工作任务节点名称与审批人列出(排除了会签的情况),即以节点名称为key,审批人为value,如下:

for(ProcessTaskEntity task : processTaskList){
		map.put(task.getActivityName(), task.getCreateUserCode());
		}
		taskVo.setActivityUserMap(map);

 activityUserMap这个属性是Map类型,传到前端后我希望遍历这个Map类型的数据,分别取到其keyvalueMap类型的在前端其value={a=b,c=d,e=f},在前端使用foreach进行遍历的时候将其等同于一般字符串,第一位是{,第二位是a,以此类推。这并不符合我们使用Map类型的初衷。

  所以我们使用了JsonObject类型声明activityUserMap,上面的代码不需要做任何修改,即可得到一个JsonObjectactivityUserMap,在前端使用如下方法遍历:

	var activityUserMap = ${taskVo.activityUserMap};
$.each(activityUserMap, function(key, value) { 
var temp= "<option value='" + key + "'>" + key + "</option>";
$('select[name="activityNameChoose"]').append(temp);
});

这段代码,如果是纯Java的,是简单清晰的。但用Js来写,有好多曲折:

1.JQuery获得的控件不能再用.options.add()等方法;

2.$('select[name="activityNameChoose"]')后不能加[0]; 

3.Temp的内容如果写在append里会报undefined is not a function,原因不明。

2.select选中值的问题

经过试验后的正确取值方法是

 $("select[name='activityNameChoose']").val()

而不正确的取值方法


$("input[name='uidscb']:checked").val()
$("input[name='uidscb']:checked").value
$("select[name='activityNameChoose']").value;

另外,其他方法比如$("select[name='activityNameChoose']").options也无法获得select的所有options选项。

3.$("input[name='XXX']:not(:checked)"):取得select未选中值的方法

  关于使用JQuery操作select的详细方法可以参看:jQuery select操作控制方法小结。另外关于JQuery的遍历请查看$.each遍历map、array。另外在解决上述问题的过程中还参考了JQuery的三种$的三种实现。


向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI