作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
function scramble(a){a=a.split("");for(var b=a.length-1;0<b;b--){var c=Math.floor(Math.random()*(b+1));d=a[b];a[b]=a[c];a[c]=d}return a.join("")}
我有这段代码,它似乎可以有效地通过调用警报来打乱单个单词:
alert(scramble('Like this.'));
这就是我想要做的:我希望能够在文本区域中输入文本,用换行符分隔,并逐行随机打乱每个字符串。例如:
testing
scramble
words
会输出类似的内容:
sgnitte
rceamslb
dwros
谁能帮我做这件事吗?
最佳答案
function shuffle(str) {
var str = document.getElementById('txt');
var a = str.innerHTML;
var newArr = [];
var neww = '';
var text = a.replace(/[\r\n]/g, '').split(' ');
text.map(function(v) {
v.split('').map(function() {
var hash = Math.floor(Math.random() * v.length);
neww += v[hash];
v = v.replace(v.charAt(hash), '');
});
newArr.push(neww);
neww = '';
});
var x = newArr.map(v => v.split('').join(' ')).join('\n');
str.value = x.split('').map(v => v.toUpperCase()).join('');
}
<textarea cols='60' rows='8' id="txt">testing scramble words</textarea>
<button onclick='shuffle()'>Shuffle</button>
关于javascript - 创建 JavaScript 字符串/单词扰码器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42334640/
我是一名优秀的程序员,十分优秀!