JQuery BUG : $.attr("selected",true)

Jquery版本:1.10.2

GOOGLE CHROME浏览器可正常执行。

IE11和FIREFOX 26出现BUG。

后来的评论让我了解到,我该看文档了!其实该用$.prop("selected",true),谢谢sdhongjun 


<select id="id123" name="id123" multiple="multiple">

<option>test 1</option>

<option>test 2</option>

<option>test 3</option>

<option>test 4</option>

</select>


为了向服务器提交多选,需要先选中所有option。然而,进行JQUERY的$("#id123 option").attr("selected",true)时,易出现BUG,特此记录。


BUG重现:手动点击选项(手动点击的目的可能是排序选项等),再进行JQUERY的$("#id123 option").attr("selected",true)时,所有option源码都会设置selected="selected",但是并没有高亮选中状态,此时提交服务器,将只接收高亮选中状态的值。


解决方案:重回JAVASCRIPT


var sel = document.getElementById("id123");
            for (var i = 0; i < sel.options.length; i++) {
                sel.options[i].selected = true;
            }





  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
我在使用vue2和echarts作图 组图部分代码为 let dataMap = {}; //返回数据根据name分组 this.responseData.forEach(item => { if (!dataMap[item.nameWithIp]) { dataMap[item.nameWithIp] = { name: item.nameWithIp, type: 'line', data: [], }; } dataMap[item.nameWithIp].data.push({ value: [item.monitorDate, item[this.request.queueAttribute]], name: item.name, server:item.server, monitorDate: item.monitorDate, queueSize: item.queueSize, enqueueCount: item.enqueueCount, dequeueCount: item.dequeueCount, enqueueCountDiff: item.enqueueCountDiff, dequeueCountDiff: item.dequeueCountDiff, consumerCount: item.consumerCount, producerCount: item.producerCount, symbol: 'circle', // 配置标记样式 symbolSize: 4, // 配置标记大小 }); }); let seriesData = Object.values(dataMap); let myChartOptions = { tooltip: { trigger: 'item', axisPointer: { type: 'line', lineStyle: { color: '#999' } }, formatter: params => { let data = params.data; return 队列名称: ${data.name}<br/> 队列ip: ${data.server}<br/> 时间: ${data.monitorDate}<br/> 积压数: ${data.queueSize}<br/> 总生产数: ${data.enqueueCount}<br/> 生产数: ${data.enqueueCountDiff}<br/> 总消费数: ${data.dequeueCount}<br/> 消费数: ${data.dequeueCountDiff}<br/> 生产者数: ${data.consumerCount}<br/> 消费者数: ${data.producerCount} }, }, xAxis: { type: 'time', }, yAxis: { type: 'value', }, series: seriesData, }; let myChart = this.$echarts.init(document.getElementById("myChart")); myChart.clear(); myChart.setOption(myChartOptions) 在这段代码中有一行value: [item.monitorDate, item[this.request.queueAttribute]], 这里需要更改,因为原来的this.request.queueAttribute是一个字符串,而新的this.request.queueAttribute改为了一个列表,里面有多个字符串,现在我需要针对this.request.queueAttribute里的每个字符串做出一条折线,我该怎么修改代码
06-09

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值