Uncaught TypeError: Cannot read property 'replace' of null jqgrid
Uncaught TypeError: Cannot read property 'replace' of null jqgrid
我是编程新手。当我尝试下面的功能时,除非列中有空白单元格,否则它运行良好。如果单元格中有任何空白值,则它不起作用,然后整个页面变为空白。请帮我解决一下。
function growth (cellvalue) {
var gcolor;
var numval=cellvalue
var val = Number(numval.replace("%",""));
if (val<0) {
gcolor = 'red';
} else if (val>0) {
gcolor = 'green';
}
return '<span class="cellWithoutBackground" style="background-color:' + gcolor + ';">' + cellvalue + '</span>';
};
我也在下面尝试过不等于 null 像这样 if (val !== null && val<0)
function growth (cellvalue) {
var gcolor;
var numval=cellvalue
var val = Number(numval.replace("%",""));
if (val !== null && val<0) {
gcolor = 'red';
} else if (val !== null && val>0) {
gcolor = 'green';
}
return '<span class="cellWithoutBackground" style="background-color:' + gcolor + ';">' + cellvalue + '</span>';
};
当没有空白单元格时,两者都可以正常工作。但是当有空白单元格时,它不起作用。请帮忙
更新
function growth (cellvalue) {
var numval=cellvalue
if(numval != null || numval != '' || numval != "")
{
var gcolor;
var val = Number(numval.replace("%",""));
if(val<0) {gcolor = 'red';}
else if(val >0) {gcolor = 'green';}
return '<span class="cellWithoutBackground" style="background-color:' + gcolor + ';">' + cellvalue + '</span>';
};
else{return '<span class="cellWithoutBackground" style="background-color:' + white + ';">' + cellvalue + '</span>';};
您可以设置全局条件,例如
function growth (cellvalue) {
if(cellvalue != null || cellvalue!= '' || cellvalue != "") {
// do stuff here
}
else {
//nothing do
}
}
您应该在 尝试解析该值之前测试 cellvalue != null
。测试 cellvalue != null
意味着在 JavaScript 中与 cellvalue !== null || cellvalue !== undefined
相同。在这两种情况下,您都不应使用 cellvalue.replace
(或 numval.replace
)。
代码中的下一个可能问题是使用 numeric 值作为输入数据。例如,您可以使用 123
而不是 "123"
。 Number 类型没有方法 replace
,您可能还会遇到一个错误。如果数字还不是字符串,我建议您使用 String(cellvalue)
将数字转换为字符串。
试试
function growth (cellvalue) {
if (cellvalue == null) { // test for null or undefined
return "";
}
cellvalue = Number(String(cellvalue).replace("%",""));
return '<span class="cellWithoutBackground" style="background-color:' +
(cellvalue < 0 ? 'red' : 'green') +
';">' + cellvalue + '</span>';
}
我是编程新手。当我尝试下面的功能时,除非列中有空白单元格,否则它运行良好。如果单元格中有任何空白值,则它不起作用,然后整个页面变为空白。请帮我解决一下。
function growth (cellvalue) {
var gcolor;
var numval=cellvalue
var val = Number(numval.replace("%",""));
if (val<0) {
gcolor = 'red';
} else if (val>0) {
gcolor = 'green';
}
return '<span class="cellWithoutBackground" style="background-color:' + gcolor + ';">' + cellvalue + '</span>';
};
我也在下面尝试过不等于 null 像这样 if (val !== null && val<0)
function growth (cellvalue) {
var gcolor;
var numval=cellvalue
var val = Number(numval.replace("%",""));
if (val !== null && val<0) {
gcolor = 'red';
} else if (val !== null && val>0) {
gcolor = 'green';
}
return '<span class="cellWithoutBackground" style="background-color:' + gcolor + ';">' + cellvalue + '</span>';
};
当没有空白单元格时,两者都可以正常工作。但是当有空白单元格时,它不起作用。请帮忙
更新
function growth (cellvalue) {
var numval=cellvalue
if(numval != null || numval != '' || numval != "")
{
var gcolor;
var val = Number(numval.replace("%",""));
if(val<0) {gcolor = 'red';}
else if(val >0) {gcolor = 'green';}
return '<span class="cellWithoutBackground" style="background-color:' + gcolor + ';">' + cellvalue + '</span>';
};
else{return '<span class="cellWithoutBackground" style="background-color:' + white + ';">' + cellvalue + '</span>';};
您可以设置全局条件,例如
function growth (cellvalue) {
if(cellvalue != null || cellvalue!= '' || cellvalue != "") {
// do stuff here
}
else {
//nothing do
}
}
您应该在 尝试解析该值之前测试 cellvalue != null
。测试 cellvalue != null
意味着在 JavaScript 中与 cellvalue !== null || cellvalue !== undefined
相同。在这两种情况下,您都不应使用 cellvalue.replace
(或 numval.replace
)。
代码中的下一个可能问题是使用 numeric 值作为输入数据。例如,您可以使用 123
而不是 "123"
。 Number 类型没有方法 replace
,您可能还会遇到一个错误。如果数字还不是字符串,我建议您使用 String(cellvalue)
将数字转换为字符串。
试试
function growth (cellvalue) {
if (cellvalue == null) { // test for null or undefined
return "";
}
cellvalue = Number(String(cellvalue).replace("%",""));
return '<span class="cellWithoutBackground" style="background-color:' +
(cellvalue < 0 ? 'red' : 'green') +
';">' + cellvalue + '</span>';
}