写入时更改输入字段值

Changing input field value while writing

假设我有一个输入字段

<input type="text" class="form-control" name="filename">

并写下这样的东西:

Hällo

是否可以在写入时检查该字段是否有字母 ä 并在写入时将其更改为 a

到目前为止,我构建了这个:

$search  = array('ä', 'Ä');
$replace = array('ae', 'Ae');

$project = str_replace($search, $replace, $input);

你不会用 PHP 做这个,你会用 Javascript:

var el = document.getElementById("filename");
el.addEventListener('keyup', function(){
    var replace = ['ä','å'];
    var replacewith = 'a';
    var replace1 = ['ö'];
    var replacewith1 = 'o';
    replace.forEach(function(letter){
        el.value = el.value.replace(letter, replacewith);
    });
    replace1.forEach(function(letter){
        el.value = el.value.replace(letter, replacewith1);
    });
});

id="filename" 添加到输入元素以使其生效。您可以根据需要向替换数组添加任意数量的字母。 您还可以添加更多数组来替换字母。

https://jsfiddle.net/dek5as1x/1

编辑:几个字母的解决方案

var el = document.getElementById("filename");
el.addEventListener('keyup', function(){
    var replaces = [['ä','å'],['ö','ø'],['ï','ì'],['ü','ù','û'],['ë','ê']];
    var replacewith = ['a','o','i','u','e'];
    replaces.forEach(function(letterGroup, index){
        letterGroup.forEach(function(letter){
            el.value = el.value.replace(letter, replacewith[index]);
        });
    });
});

这里你添加一个新数组([])来替换。然后将所有字母添加到该数组中,这些字母应该变成与该数组相同的字母。示例:['ê','ë','è']。然后将字母添加到 replacewith 数组。重要的是字母来替换数组中的字母与替换中的相应数组具有相同的索引。 当你有很多字母要替换时,这个解决方案应该更干净一些。

您不能使用 PHP 执行此操作,因为 PHP 是服务器端。

但是您可以使用 JavaScript 来做到这一点。 尝试:

<script language="JavaScript">
function replace() {
var input = document.getElementById("filename");
input.value = input.value.replace("ä","a");
}
<script>

<input type="text" class="form-control" name="filename" onchange="replace()">