我无权访问后端组件,但您链接的演示包含前端代码,看起来您可以在那里破解。看起来这个控件可能既是客户端服务器又是客户端。对于客户端,只有黑客看起来有点复杂,并且涉及非公共 API (_onInputChange),但对于客户端-服务器案例(可能是你的情况),client side of RadComboBox Object 上的文档提到了 requestItems 方法,所以黑客可能是未来相当安全:
var hackRadComboBoxFilter = function (combobox, filterProcessingFunction) {
var oldRequestItems = combobox.requestItems;
combobox.requestItems = function() {
var args = Array.prototype.slice.call(arguments);
// requestItems has several arguments but the text seems to be the
// first one, so let's modify it and call the original method
var origFilter = args[0];
args[0] = filterProcessingFunction(origFilter);
oldRequestItems.apply(this, args);
}
};
不幸的是,我不知道在 JS 中处理重音的内置方法,但您也可以在这里破解一些简单的东西:
var accents = 'ÀÁÂÃÄÅàáâãäåÒÓÔÕÕÖØòóôõöøÈÉÊËèéêëðÇçÐÌÍÎÏìíîïÙÚÛÜùúûüÑñŠšŸÿýŽž';
var mappedAccents = "AAAAAAaaaaaaOOOOOOOooooooEEEEeeeeeCcDIIIIiiiiUUUUuuuuNnSsYyyZz";
var removeAccents = function (origStr) {
var components = [];
var len = origStr.length;
var afterLastAccent = 0;
for (var i = 0; i < len; i++) {
var mapPos = accents.indexOf(origStr[i]);
if (mapPos != -1) {
components.push(origStr.substr(afterLastAccent, i - afterLastAccent) + mappedAccents[mapPos]);
afterLastAccent = i + 1;
}
}
if (afterLastAccent < len)
components.push(origStr.substr(afterLastAccent, len - afterLastAccent));
return components.join('');
};
所以现在你可以把它组合成这样:
// In real app you probably want something like this
// var targetComboBox = $find("<%= RadComboBox1.ClientID %>");
// but for test let's just hack first combobox on the page
var targetComboBox = Telerik.Web.UI.RadComboBox.ComboBoxes[0];
hackRadComboBoxFilter(targetComboBox, removeAccents);
或者如果您想修改页面上的所有组合框,您可以使用相同的技巧更改原型:
hackRadComboBoxFilter(Telerik.Web.UI.RadComboBox.prototype, removeAccents)