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 相关文章推荐
jQuery实现返回顶部功能适合不支持js的浏览器
Aug 19 Javascript
setinterval()与clearInterval()JS函数的调用方法
Jan 21 Javascript
浅谈angular.js中实现双向绑定的方法$watch $digest $apply
Oct 14 Javascript
javascript点击按钮实现隐藏显示切换效果
Feb 03 Javascript
使用HTML5+Boostrap打造简单的音乐播放器
Aug 05 Javascript
使用Ajax与服务器(JSON)通信实例
Nov 04 Javascript
JavaScript数据结构之二叉树的删除算法示例
Apr 13 Javascript
微信小程序实现笑脸评分功能
Nov 03 Javascript
详解js根据百度地图提供经纬度计算两点距离
May 13 Javascript
file-loader打包图片文件时路径错误输出为[object-module]的解决方法
Jan 03 Javascript
keep-Alive搭配vue-router实现缓存页面效果的示例代码
Jun 24 Javascript
微信小程序弹窗禁止页面滚动的实现代码
Dec 30 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
mysql 全文搜索 技巧
2007/04/27 PHP
PHP GD 图像处理组件的常用函数总结
2010/04/28 PHP
php实现的常见排序算法汇总
2014/09/08 PHP
PHP 搜索查询功能实现
2016/11/29 PHP
各情景下元素宽高的获取实现代码
2011/09/13 Javascript
JQuery获取或设置ckeditor的数据(示例代码)
2013/11/15 Javascript
js跨域访问示例(客户端/服务端)
2014/05/19 Javascript
For循环中分号隔开的3部分的执行顺序探讨
2014/05/27 Javascript
angularjs 处理多个异步请求方法汇总
2015/01/06 Javascript
jQuery中extend函数详解
2015/02/13 Javascript
BootStrap智能表单实战系列(九)表单图片上传的支持
2016/06/13 Javascript
微信小程序 基础组件与导航组件详细介绍
2017/02/21 Javascript
jQuery中Chosen三级联动功能实例代码
2017/03/07 Javascript
JavaScript运动框架 解决防抖动问题、悬浮对联(二)
2017/05/17 Javascript
vue 解决循环引用组件报错的问题
2018/09/06 Javascript
JS实现处理时间,年月日,星期的公共方法示例
2019/05/31 Javascript
Layer组件多个iframe弹出层打开与关闭及参数传递的方法
2019/09/25 Javascript
vux-scroller实现移动端上拉加载功能过程解析
2019/10/08 Javascript
详解JS预解析原理
2020/06/16 Javascript
[06:44]2018DOTA2亚洲邀请赛4.5 SOLO赛 MidOne vs Sumail
2018/04/06 DOTA
Python自动登录126邮箱的方法
2015/07/10 Python
Python实现的网页截图功能【PyQt4与selenium组件】
2018/07/12 Python
python障碍式期权定价公式
2019/07/19 Python
Linux下通过python获取本机ip方法示例
2019/09/06 Python
Python 如何反方向迭代一个序列
2020/07/28 Python
附答案的Java面试题
2012/11/19 面试题
C++面试题:关于链表和指针
2013/06/05 面试题
大型活动策划方案
2014/01/12 职场文书
棉花姑娘教学反思
2014/02/15 职场文书
乡镇网格化管理实施方案
2014/03/23 职场文书
大学专科求职信
2014/07/02 职场文书
2014年督导工作总结
2014/11/19 职场文书
政审证明范文
2015/06/19 职场文书
二手手机买卖合同范本(2019年版)
2019/10/28 职场文书
如何Python使用re模块实现okenizer
2022/04/30 Python
Java获取字符串编码格式实现思路
2022/09/23 Java/Android