JS+CSS实现的漂亮渐变背景特效代码(6个渐变效果)


Posted in Javascript onMarch 25, 2016

本文实例讲述了JS+CSS实现的漂亮渐变背景特效代码。分享给大家供大家参考,具体如下:

运行效果截图如下:

JS+CSS实现的漂亮渐变背景特效代码(6个渐变效果)

具体代码如下:

<html>
  <head>
    <title>
      JS配合CSS实现的漂亮渐变背景特效6个实例
    </title>
    <script>
      var setGradient = (function() {
        var p_dCanvas = document.createElement('canvas');
        var p_useCanvas = !!(typeof(p_dCanvas.getContext) == 'function');
        var p_dCtx = p_useCanvas ? p_dCanvas.getContext('2d') : null;
        var p_isIE =
        /*@cc_on!@*/
        false;
        try {
          p_dCtx.canvas.toDataURL()
        } catch(err) {
          p_useCanvas = false;
        };
        if (p_useCanvas) {
          return function(dEl, sColor1, sColor2, bRepeatY) {
            if (typeof(dEl) == 'string') dEl = document.getElementById(dEl);
            if (!dEl) return false;
            var nW = dEl.offsetWidth;
            var nH = dEl.offsetHeight;
            p_dCanvas.width = nW;
            p_dCanvas.height = nH;
            var dGradient;
            var sRepeat;
            if (bRepeatY) {
              dGradient = p_dCtx.createLinearGradient(0, 0, nW, 0);
              sRepeat = 'repeat-y';
            } else {
              dGradient = p_dCtx.createLinearGradient(0, 0, 0, nH);
              sRepeat = 'repeat-x';
            }
            dGradient.addColorStop(0, sColor1);
            dGradient.addColorStop(1, sColor2);
            p_dCtx.fillStyle = dGradient;
            p_dCtx.fillRect(0, 0, nW, nH);
            var sDataUrl = p_dCtx.canvas.toDataURL('image/png');
            with(dEl.style) {
              backgroundRepeat = sRepeat;
              backgroundImage = 'url(' + sDataUrl + ')';
              backgroundColor = sColor2;
            };
          }
        } else if (p_isIE) {
          p_dCanvas = p_useCanvas = p_dCtx = null;
          return function(dEl, sColor1, sColor2, bRepeatY) {
            if (typeof(dEl) == 'string') dEl = document.getElementById(dEl);
            if (!dEl) return false;
            dEl.style.zoom = 1;
            var sF = dEl.currentStyle.filter;
            dEl.style.filter += ' ' + ['progid:DXImageTransform.Microsoft.gradient( GradientType=', +( !! bRepeatY), ',enabled=true,startColorstr=', sColor1, ', endColorstr=', sColor2, ')'].join('');
          };
        } else {
          p_dCanvas = p_useCanvas = p_dCtx = null;
          return function(dEl, sColor1, sColor2) {
            if (typeof(dEl) == 'string') dEl = document.getElementById(dEl);
            if (!dEl) return false;
            with(dEl.style) {
              backgroundColor = sColor2;
            };
          }
        }
      })();
    </script>
    <style>
      body{font:0.75em/1.4 Arial;text-align:left;margin:20px;} hr{clear:both;visibility:hidden;}
      xmp{font:12px/12px "Courier New";background:#fff;color:#666; border:solid
      1px #ccc;} div.example{ border:solid 1px #555;margin:0 20px 20px 0;float:left;
      display:inline;margin:1em;background:#fff;width:300px;padding:40px;color:#222;font:xx-small/1.2
      "Tahoma";text-align:justify;}
    </style>
    <body>
      <div id="example1" class="example">
        CSS特效代码。
      </div>
      <div id="example2" class="example">
        各类编程源码、
      </div>
      <div id="example3" class="example">
        精品软件
      </div>
      <div id="example4" class="example">
        上海世博园
      </div>
      <div id="example5" class="example">
        我家北京天安门
      </div>
      <div id="example6" class="example">
        北京欢迎您!
      </div>
      <script>
        setGradient('example1', '#4ddbbe', '#d449cc', 1);
        setGradient('example2', '#46ddbd', '#d8b617', 0);
        setGradient('example3', '#c81fc1', '#bf445f', 1);
        setGradient('example4', '#2285e5', '#d769eb', 0);
        setGradient('example5', '#8b4286', '#eac87d', 1);
        setGradient('example6', 'black', 'white', 0);
      </script>
    </body>
</html>

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
Ajax,UTF-8还是GB2312 eval 还是execScript
Nov 13 Javascript
javascript生成随机大小写字母的方法
Feb 20 Javascript
Angularjs基础知识及示例汇总
Jan 22 Javascript
微信小程序实现滑动删除效果
May 19 Javascript
JS与jQuery实现ListBox上移,下移,左移,右移操作功能示例
May 31 jQuery
微信小程序项目实践之主页tab选项实现
Jul 18 Javascript
Vue中控制v-for循环次数的实现方法
Sep 26 Javascript
vue中轮训器的使用
Jan 27 Javascript
详解Js里的for…in和for…of的用法
Mar 28 Javascript
在vue中把含有html标签转为html渲染页面的实例
Oct 28 Javascript
js new Date()实例测试
Oct 31 Javascript
基于javascript实现日历功能原理及代码实例
May 07 Javascript
详解Javascript继承的实现
Mar 25 #Javascript
JavaScript实现弹出DIV层同时页面背景渐变成半透明效果
Mar 25 #Javascript
JavaScript修改作用域外变量的方法
Mar 25 #Javascript
JavaScript 2048 游戏实例代码(简单易懂)
Mar 25 #Javascript
JavaScript入门系列之知识点总结
Mar 24 #Javascript
JS实现支持Ajax验证的表单插件
Mar 24 #Javascript
拥有一个属于自己的javascript表单验证插件
Mar 24 #Javascript
You might like
php文件上传的简单实例
2013/10/19 PHP
php查找指定目录下指定大小文件的方法
2014/11/28 PHP
php命令行模式代码实例详解
2021/02/26 PHP
JavaScript去掉数组中的重复元素
2011/01/13 Javascript
Jquery和JS用外部变量获取Ajax返回的参数值的方法实例(超简单)
2013/06/17 Javascript
jQuery实现自定义右键菜单的树状菜单效果
2015/09/02 Javascript
jquery UI Datepicker时间控件的使用方法(加强版)
2015/11/07 Javascript
微信小程序 地图定位简单实例
2016/10/14 Javascript
JS仿淘宝搜索框用户输入事件的实现
2017/06/19 Javascript
js 获取html5的data属性实现方法
2017/07/28 Javascript
详谈js中标准for循环与foreach(for in)的区别
2017/11/02 Javascript
初探Vue3.0 中的一大亮点Proxy的使用
2018/12/06 Javascript
JS实现指定区域的全屏显示功能示例
2019/04/25 Javascript
toString.call()通用的判断数据类型方法示例
2020/08/28 Javascript
[01:29:17]RNG vs Liquid 2019国际邀请赛淘汰赛 败者组 BO3 第二场 8.23
2019/09/05 DOTA
Python函数中的函数(闭包)用法实例
2016/03/15 Python
Python实现优先级队列结构的方法详解
2016/06/02 Python
Python基于多线程实现抓取数据存入数据库的方法
2018/06/22 Python
Python中按键来获取指定的值
2019/03/02 Python
python实现二级登陆菜单及安装过程
2019/06/21 Python
python命名空间(namespace)简单介绍
2019/08/10 Python
django连接mysql数据库及建表操作实例详解
2019/12/10 Python
Python如何根据时间序列数据作图
2020/05/12 Python
利用canvas实现图片下载功能来实现浏览器兼容问题
2019/05/31 HTML / CSS
浅谈html5标签css3的常用样式
2016/10/20 HTML / CSS
HTML5拖拽API经典实例详解
2018/04/20 HTML / CSS
Contém1g官网:巴西彩妆品牌
2020/01/17 全球购物
使用索引有什么好处
2016/07/27 面试题
软件测试企业面试试卷
2016/07/13 面试题
周鸿祎:教你写创业计划书
2013/12/30 职场文书
大学生会计职业生涯规划范文
2014/02/28 职场文书
开学典礼策划方案
2014/05/28 职场文书
不听老师话的万能检讨书
2014/10/04 职场文书
2015年上半年物业工作总结
2015/03/30 职场文书
2016年国培研修日志
2015/11/13 职场文书
七年级作文(600字3篇)
2019/09/24 职场文书