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 相关文章推荐
JavaScript Prototype对象
Jan 07 Javascript
jQuery学习3:操作元素属性和特性
Feb 07 Javascript
jQuery实战之仿淘宝商城左侧导航效果
Apr 12 Javascript
JS正则表达式验证数字代码
Jan 28 Javascript
JavaScript实现一个空中避难的小游戏
Jun 06 Javascript
基于vue2框架的机器人自动回复mini-project实例代码
Jun 13 Javascript
详解extract-text-webpack-plugin 的使用及安装
Jun 12 Javascript
微信小程序中使用ECharts 异步加载数据的方法
Jun 27 Javascript
javascript实现考勤日历功能
Nov 29 Javascript
VueJS 组件参数名命名与组件属性转化问题
Dec 03 Javascript
Vue实现开关按钮拖拽效果
Sep 22 Javascript
Vue项目中使用mock.js的完整步骤
Jan 12 Vue.js
详解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类自动装载、链式操作、魔术方法实现代码
2017/07/23 PHP
php+jQuery ajax实现的实时刷新显示数据功能示例
2019/09/12 PHP
KindEditor在php环境下上传图片功能集成的方法示例
2020/07/20 PHP
Jqgrid表格随窗口大小改变而改变的简单实例
2013/12/28 Javascript
多引号嵌套的变量命名的问题
2014/05/09 Javascript
jQuery实现防止提交按钮被双击的方法
2015/03/24 Javascript
js简单工厂模式用法实例
2015/06/30 Javascript
JS实现的自定义网页拖动类
2015/11/06 Javascript
js判断移动端是否安装某款app的多种方法
2015/12/18 Javascript
一分钟理解js闭包
2016/05/04 Javascript
浅析jQuery Ajax通用js封装
2016/06/22 Javascript
JavaScipt选取文档元素的方法(推荐)
2016/08/05 Javascript
jQuery中$.ajax()方法参数解析
2016/10/22 Javascript
微信公众号  提示:Unauthorized API function 问题解决方法
2016/12/05 Javascript
详解Nodejs基于mongoose模块的增删改查的操作
2016/12/21 NodeJs
angularJS深拷贝详解
2017/03/23 Javascript
vue2.X组件学习心得(新手必看篇)
2017/07/05 Javascript
解决vue里碰到 $refs 的问题的方法
2017/07/13 Javascript
解决vue-quill-editor上传内容由于图片是base64的导致字符太长的问题
2018/08/20 Javascript
详解webpack打包vue项目之后生成的dist文件该怎么启动运行
2019/09/06 Javascript
微信小程序如何实现五星评价功能
2019/10/15 Javascript
vue el-upload上传文件的示例代码
2020/12/21 Vue.js
[58:18]2018DOTA2亚洲邀请赛3月29日 小组赛B组 iG VS Mineski
2018/03/30 DOTA
python爬虫爬取淘宝商品信息(selenum+phontomjs)
2018/02/24 Python
python正则-re的用法详解
2019/07/28 Python
Pytorch Tensor的索引与切片例子
2019/08/18 Python
基督教卡片、励志礼品、家居装饰等:DaySpring
2018/10/12 全球购物
自我鉴定 电子商务专业
2014/01/30 职场文书
人力资源管理专业应届生求职信
2014/04/24 职场文书
奉献爱心演讲稿
2014/09/04 职场文书
奔腾年代观后感
2015/06/09 职场文书
小学数学教师研修日志
2015/11/13 职场文书
2016反腐倡廉警示教育心得体会
2016/01/13 职场文书
Golang二维数组的使用方式
2021/05/28 Golang
MySQL GRANT用户授权的实现
2021/06/18 MySQL
总结几个非常实用的Python库
2021/06/26 Python