2

我正在尝试通过 GET ajax 调用将一些十六进制颜色传递给 php 脚本。PHP 似乎不喜欢十六进制颜色,但我尝试替换#并使用encodeURIComponent这两种颜色都不起作用。

这是js(每个currentColors条目都是十六进制颜色)

var dataString = 'designName=test&mc1='+currentColors[1]+'&mc0='+currentColors[0]+'&sp='+currentColors[2];
var strippedString = encodeURIComponent(dataString);
4

2 回答 2

4

用于encodeURIComponent编码 URI组件

var strippedString = 
    "designName=test" + 
    "&mc1=" + encodeURIComponent(currentColors[1]) +
    "&mc0=" + encodeURIComponent(currentColors[0]) +
    "&sp="  + encodeURIComponent(currentColors[2]);

例子:

var strippedString = 
    "designName=test" + 
    "&mc1=" + encodeURIComponent("#FF0000") +
    "&mc0=" + encodeURIComponent("#00FF00") +
    "&sp="  + encodeURIComponent("#0000FF");
// "designName=test&mc1=%23FF0000&mc0=%2300FF00&sp=%230000FF"

在服务器端,查询字符串将产生:

// parse_str("designName=test&mc1=%23FF0000&mc0=%2300FF00&sp=%230000FF", $my_GET);
// var_dump($my_GET);

array(4) {
  ["designName"]=>
  string(4) "test"
  ["mc1"]=>
  string(7) "#FF0000"
  ["mc0"]=>
  string(7) "#00FF00"
  ["sp"]=>
  string(7) "#0000FF"
}
于 2012-12-19T09:17:00.987 回答
0

你可以这样做:

var strippedString = dataString.split('#').join('');

然后,在服务器端,'#'再次添加到参数中。


.split('#')在字符处将字符串拆分为数组'#'

var s = 'designName=test&mc1=#FF0000&mc0=#FFFFFF&sp=#FF00FF';
var a = s.split('#');
console.log(a);
//["designName=test&mc1=", "FF0000&mc0=", "FFFFFF&sp=", "FF00FF"]

.join('')然后再次将此数组连接在一起:

var s = a.join('');
console.log(s);
//'designName=test&mc1=FF0000&mc0=FFFFFF&sp=FF00FF'

您还可以在以下位置使用占位符/替换字符串.join('')

var s = a.join('%');
console.log(s);
//'designName=test&mc1=%FF0000&mc0=%FFFFFF&sp=%FF00FF'

或者,就像Salman A 回答的那样,encodeURIComponent仅在组件上使用。(这无疑比我建议的数组函数快)

于 2012-12-19T09:13:10.893 回答