技术解析

请教一下,怎么把这段代码换一个优雅的写法
0
2021-08-20 05:58:45
idczone

如下所示,一段拼接的 html 字符串,想要根据接受到的 value 不同,给不同的 radio 加 checked 属性。
这样写实在太丑了
var value = field.value;
var checked1 = "";
var checked2 = "";
var checked3 = "";
var checked4 = "";
var checked5 = "";
var checked6 = "";
var checked7 = "";
switch(value){
case "1":
checked1 = "checked";
break;
case "2":
checked2 = "checked";
break;
case "3":
checked3 = "checked";
break;
case "4":
checked4 = "checked";
break;
case "5":
checked5 = "checked";
break;
case "6":
checked6 = "checked";
break;
case "7":
checked7 = "checked";
break;
}
var html = ''+
''+
''+
''+
''+
''+
'';
return html;


能用就行

你是个后端吧

没错,我是个后端 o(╥﹏╥)o

赞同

不要拼接 HTML,直接操作 DOM

请教一下,怎么把这坨屎换一个优雅的吃法

把值放数组里面,用下标存取数据

后端通常有模板化的写法,不需要拼接字符串

写的好看有球用,用户又看不到

var someJson ={
}
$.each(someJson, function (k, v) {
//判断条件
if (){
var ele = ""//html 拼接
}
//直接加到 html 里面
$("/> })

var checked = [false,false,false,false]; checked[value] = true

let html = '';
let TimeArr = ['日','周','半月','月','季','半年','年',]
for(let i=1;i<7;i++){
if(i==field.value){
html += ''
}else{
html += ''
}
}
return html;
=================================
献丑

let value = field.value
let h = ''
let titleArray = ['日','周','半月']
return titleArray.forEach((e,idx) => {
h += ``
});

看头像还是个夏娜粉??
你可以使用 JS 操作 DOM 动态设置,把这些 input 直接写到 html 里,不用带 checked,记得用 class 或 id 把年月日这些区分开。
用 element.checked = true 设置 element 为 checked 状态,然后用 element.removeAttribute('checked'); 移除 element 的这个属性。
然后你再根据 value 设置 checked 状态。例如:
var v = field.value;
switch(v){
case 1: document.querySelector('.select-year').checked = true; break;
case 2: document.querySelector('.select-month').checked = true; break;
}
不需要用 JS 构建 direct HTML 的。这种既乱又不好进行扩展。

我来领打脸了,没有跑过就放代码,后面看到的不要抽我脸
=====
function getType(e) {
let html = '';
let TimeArr = ['日','周','半月','月','季','半年','年']
for(let i=1;i<=7;i++){
if(i==e){
html += ''
}else{
html += ''
}
}
return html;
}
=====

var value = field.value;
var config = [
{ value: 1, title: '日', checked: null },
{ value: 2, title: '周', checked: null },
{ value: 3, title: '半月', checked: null },
{ value: 4, title: '月', checked: null },
{ value: 5, title: '季', checked: null },
{ value: 6, title: '半年', checked: null },
{ value: 7, title: '年', checked: null },
];
config[value - 1].checked = 'checked';
var radioInit = (value, checked, title) => ``;
var html = config.reduce((acc, cur) => {
return acc + radioInit(cur.value, cur.checked, cur.title);
}, '');
return html;

编程珠玑中吐槽了这种写法。用数组。建立适用的数据结构让程序更加优美。

哈哈哈,至少你写的结构比我好看多了,不要在意细节

感谢各位大胸弟,又学到了不少

嗯...config 里面 checked: null 可以去掉...习惯预设属性了
@jeodeng

用 map

不管前后端都要活用数组与 MAP,代码要像裙子越短越好

const periods = ['日','周','半月','月','季','半年','年'];
const checked = 2;
const html = periods.map((v,i) => `${i === checked ? 'checked' : ''} title="${periods[i]}" lay-filter="cycle_type">`).join("\n")

hhh

这段代码 hin 叼

用字典


var value = field.value;
var radioId = 'cycle_type';
var titleArr= ["", "日", "周", "半月", "月", "季", "半年", "年"]
for(var i = 1;i < titleArr.length;i++) {
var rt = $("/> rt.attr("id", radioId + i);
rt.attr("value", i);
rt.attr("title", titleArr[i]);
rt.prop("checked", i == value);
rt.attr("style", "");
$("/>}
老式 jQuery 法,后端专用

楼上动不动就 let const 和 箭头函数的,莫非都是默认楼主用 babel 的?

我刚搜了下,浏览器不支持这种写法吗?我看写 vue 的都这么写 js

友情提示:记得把 let 和 const 换成 var

正儿八经进了语言标准的东西,怎么就不能用了,又不是草案语法。讨论个写法问题还得考虑 ie 兼容吗

var value = field.value; field 没定义啊

2015 年之后的主流浏览器都支持这么写,至于 5 年前的老浏览器,项目不一定非要兼容

lz 也没定义啊

你一后端,这样就挺优雅了

哈哈,一看就是后端码农写的---

别用 es6 的写法呢,不兼容

语言只是表达计算的工具,就算楼主的项目不能用 ES6+,人肉 babel 把楼上的 Snippet 改改也能用。

你这是凑行数吧。感觉可以加 id 或者 class,再改变元素属性。

恭喜你,可以和蚂蚁金服 pk 行数了

欢迎来我司 因为我司每天统计代码行数

用毛笔?

function getHTML(value) {
const arr = ['日', '周', '半月', '月', '季', '半年', '年'];
let html = "";
arr.forEach((item, index) => {
html += ""
});
return html
}

return ['日', '周', '半月', '月', '季', '半年', '年'].map(
(title, index) => ``
).join('');

所以为什么要拼接字符串构建 HTML 呢,前端构建字符串 HTML 前期确实能用,但是是一大坨,后期的扩展性可维护性也很低。比如如果你后期要加东西的话,还得考虑前面的逻辑,然后再对着那一坨 HTML 改。但是如果你动态声明,每个属性显而易见,要改什么属性直接在后面加个操作就行了。前面的 都有解决的代码。
但是如果你确实要构建 HTML,那建议你使用循环,一个一个复制粘贴可能是上古写法。

vue.js 请

并不是所有浏览器支持 es6 等新的 js 语法,有些浏览器老的版本不兼容,所以才需要使用一个转换的工具就是楼上有人提到的 babel 了,它能将新的 js 语法转换成所有浏览器都支持的最原生的 js 语法

按楼主的意思写了几个版本,见笑了


看了以上的答案,还是觉得 C/>$""

这就是互联网程序员的水平?

用这种写法, 离一年 4 亿行代码的目标又近了一步

1. 把那些"日 /周 /月……"常量写在数组里
2. 根据数组,for 循环生成 html
3. 循环时,当 value 匹配,增加 checked 属性

```javascript
/**
* createRadioGroup
* createRadioGroup
* v2er
* 2020-01-14
* {String} name "Diy"
* {Array} data [{title:"date",value:1,checked:false}]
* {String} "HtmlCode"
*/
function createRadioGroup(name,data){
if(data.length == 0) return;
var html = [];
for(var i = 0; i < data.length ; i ++){
var input = window.document.createElement("input")
input.type = "radio"
input.name = name
input.value = data[i].value
input.title = data[i].title
input.defaultChecked = data[i].checked
html.push(input.outerHTML)
}
return html.join("")
}
var data = [
{title:"年",value:1,checked:true},
{title:"月",value:1,checked:false},
{title:"日",value:1,checked:false},
]
createRadioGroup("date",data);
//"
```

看样子楼主深谙命令式编程的精髓;
function resolve(value){
const time = ['日','周','半月','月','季','半年','年'];
if(!Number.isInteger(value) || value>time.length){
throw new Error(`参数错误:需要 1~7 的整数`);
}
return Array.from(Array(time.length)).reduce((result, _c, index)=>{
const template = ` id="cycle_type_${index}"
type="radio"
name="cycle_type"
value="${index+1}"
${index+1===value?"checked":''}
title="${time[index]}"
lay-filter="cycle_type">`;
return result+template
},'')
}
console.log(resolve(2));

数据地带为您的网站提供全球顶级IDC资源
在线咨询
专属客服