javascript - 如何在 Javascript 中从左到右到从右到左替换字符串的元素?

标签 javascript

在我的 HTML 中,我有一串 5 个数字。单击“删除”按钮时,数字将按从左到右的顺序替换为破折号。耶,它有效!但是我该如何替换从右到左的顺序呢?

$("#deleteButton").click(function() {
  var str = document.getElementById("dashes").innerHTML;
  var str = str.replace(/[0-9]/, "-");
  document.getElementById("dashes").innerHTML = str;

});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div id="dashes">123456789</div>
<button id="deleteButton">delete</button>

最佳答案

您必须识别最右边的数字而不是最左边的数字(正则表达式默认从左到右搜索)。请注意,您可以使用 \d 而不是 [0-9] 来减少语法噪音。一种选择是使用

/\d(?=\D*$)/

即匹配一个数字,向前查找任意数量的非数字字符,后跟字符串的末尾。

$("#deleteButton").click(function() {
  var str = document.getElementById("dashes").innerHTML;
  str = str.replace(/\d(?=\D*$)/, "-");
  document.getElementById("dashes").innerHTML = str;
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div id="dashes">123456789</div>
<button id="deleteButton">delete</button>

关于javascript - 如何在 Javascript 中从左到右到从右到左替换字符串的元素?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52340782/

相关文章:

javascript - 将 LocalStorage 与 React 结合使用?

javascript - 如何检测 contenteditable div 的内容是否被更改

javascript - 有没有一种方法可以在用户使用 javascript 和 css 键入时设置文本区域内容的样式?

javascript - 有没有办法从链接的 xpath 获取 JavaScript 中链接的目的地?

javascript - Facebook API,使用 javascript 将公共(public)页面的照片共享到用户时间轴

javascript - 如何将灯箱图像添加到 bxslider(尝试使用 colorbox)

javascript - 找到总和为目标值的所有对

javascript - 如何使用 google map api 获得精确位置?

php - AJAX 请求不发送阿拉伯字符

javascript - 如何找到真正的DIV高度?