Js生成随机颜色的七种方法
发布时间:2018-04-26, 16:41:29 分类:HTML | 编辑 off 网址 | 辅助
正文 3139字数 147,739阅读
方法一
随机生成6个字符然后再串到一起,闭包调用自身与三元运算符让程序变得内敛
<script>
var getRandomColor = function(){
return '#' +
(function(color){
return (color += '0123456789abcdef'[Math.floor(Math.random()*16)])
&& (color.length == 6) ? color : arguments.callee(color);
})('');
}
document.write('<span style="color:'+getRandomColor()+'">刷新随机颜色</span>');
</script>
Run code
Cut to clipboard
方法二
把Math对象,用于生成hex颜色值的字符串提取出来,并利用第三个参数来判断是否还继续调用自身
<script>
var getRandomColor = function(){
return (function(m,s,c){
return (c ? arguments.callee(m,s,c-1) : '#') +
s[m.floor(m.random() * 16)]
})(Math,'0123456789abcdef',5)
}
document.write('<span style="color:'+getRandomColor()+'">刷新随机颜色</span>');
</script>
Run code
Cut to clipboard
方法三
对数组做扩展,map返回一个数组,然后再用join把它的元素串成字符
<script>
Array.prototype.map = function(fn, thisObj) {
var scope = thisObj || window;
var a = [];
for ( var i=0, j=this.length; i < j; ++i ) {
a.push(fn.call(scope, this[i], i, this));
}
return a;
};
var getRandomColor = function(){
return '#'+'0123456789abcdef'.split('').map(function(v,i,a){
return i>5 ? null : a[Math.floor(Math.random()*16)] }).join('');
}
document.write('<span style="color:'+getRandomColor()+'">刷新随机颜色</span>');
</script>
Run code
Cut to clipboard
方法四
这个实现非常逆天,虽然有点小bug
hex颜色值是从#000000到#ffffff,后面那六位数是16进制数,相当于“0x000000”到“0xffffff”
实现的思路是将hex的最大值ffffff先转换为10进制,进行random后再转换回16进制
<script>
var getRandomColor = function(){
return '#'+Math.floor(Math.random()*16777215).toString(16);
}
document.write('<span style="color:'+getRandomColor()+'">刷新随机颜色</span>');
</script>
Run code
Cut to clipboard
如何得到16777215 这个数值
hex的最大值
<script>
window.onload = function () {
alert(parseInt("0xffffff",16).toString(10));
};
</script>
Run code
Cut to clipboard
方法五
基本实现方法4的改进,利用左移运算符把0xffffff转化为整型
这样就不用记16777215了
由于左移运算符的优先级比不上乘号,因此随机后再左移,连Math.floor也不用
<script>
var getRandomColor = function(){
return '#'+(Math.random()*0xffffff<<0).toString(16);
}
document.write('<span style="color:'+getRandomColor()+'">刷新随机颜色</span>');
</script>
Run code
Cut to clipboard
方法六
修正上面版本的bug(无法生成纯白色与hex位数不足问题)
0x1000000相当0xffffff+1,确保会抽选到0xffffff
在闭包里我们处理hex值不足5位的问题,直接在未位补零
<script>
var getRandomColor = function(){
return '#'+(function(h){
return new Array(7-h.length).join("0")+h
})((Math.random()*0x1000000<<0).toString(16))
}
document.write('<span style="color:'+getRandomColor()+'">刷新随机颜色</span>');
</script>
Run code
Cut to clipboard
方法七
这次在前面补零,连递归检测也省了
<script>
var getRandomColor = function(){
return '#'+('00000'+(Math.random()*0x1000000<<0).toString(16)).substr(-6);
}
document.write('<span style="color:'+getRandomColor()+'">刷新随机颜色</span>');
</script>
Run code
Cut to clipboard
(支付宝)给作者钱财以资鼓励 (微信)→
暂无评论 »