DIV+CSS+JS实现色彩渐变字体

<!DOCTYPE html>
<html>

<head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <title>DIV+CSS+JS实现色彩渐变字体</title>
    <style type="text/css">
        body {
            font: 12px/1.5 Microsoft Yahei;
        }

        h3 {
            padding: 10px;
            margin: 0;
            background-color: #999;
            color: #fff;
            font: 16px/1.5 Microsoft Yahei;
            text-align: center;
        }

        .box {
            position: relative;
            background-color: #fff;
            width: auto;
            margin: 0 auto;
            padding: 0 30px;
            font: 700 20px/1.5 "Microsoft Yahei", Microsoft Yahei;
            border-top: 1px dashed #ccc;
            border-bottom: 1px dashed #ccc;
            height: 30px;
            margin-top: 8px;
        }

        .box a {
            position: absolute;
            font-style: normal;
            white-space: nowrap;
        }

        .f999 {
            color: #999;
        }

        a:link {
            text-decoration: none;
        }

        a:hover {
            text-decoration: underline;
        }

        a:visited {
            text-decoration: none;
        }
    </style>
</head>

<body>
    <div style="width:400px;margin:200px auto;background-color:#f2f2f2;border: 1px dashed #ccc;">
        <h3><strong>CSS多彩渐变字</strong></h3>
        <table width="100%" border="0" cellspacing="0" cellpadding="0">
            <tr>
                <td height="10" colspan="2" align="center"></td>
            </tr>
            <tr>
                <td width="19%" height="30" align="right">文字:</td>
                <td width="81%"><input name="text" type="text" id="ctext" size="30" maxlength="16"
                        style="font:12px Microsoft Yahei" value="请在此输入您需要生成渐变色的文字" onkeyup="setDiv()" /></td>
            </tr>
            <tr>
                <td height="30" align="right">R值:</td>
                <td><select name="Rvalue" style="font:12px Microsoft Yahei" id="rvalue"></select>
                    <span class="f999">RGB颜色中的R值(0-255)</span></td>
            </tr>
            <tr>
                <td height="30" align="right">G值:</td>
                <td><select name="Gvalue" style="font:12px Microsoft Yahei" id="gvalue"></select>
                    <span class="f999">RGB颜色中的G值(0-255)</span></td>
            </tr>
            <tr>
                <td height="30" align="right">B值:</td>
                <td><select name="Bvalue" style="font:12px Microsoft Yahei" id="bvalue"></select>
                    <span class="f999">RGB颜色中的B值(0-255)</span></td>
            </tr>
            <tr>
                <td height="30" align="right">渐变方式:</td>
                <td><select name="ctype" style="font:12px Microsoft Yahei" id="ctype">
                        <option value="0">灰度渐变</option>
                        <option value="1" selected="selected">变化R值</option>
                        <option value="2">变化G值</option>
                        <option value="3">变化B值</option>
                    </select>
                    <span class="f999">相应的数值会强制在0~255之间变化</span></td>
            </tr>
        </table>
        <div class="box" id="box"></div>
        <br />
        <button onclick="javascript:createData()">OK,上色!</button>
        <br />

    </div>
    <script type="text/javascript">
        var rs = document.getElementById("rvalue");
        var gs = document.getElementById("gvalue");
        var bs = document.getElementById("bvalue");

        function init() {
            var str;
            for (var i = 0; i <= 255; i++) {
                var opr = document.createElement("option");
                var opg = document.createElement("option");
                var opb = document.createElement("option");
                opr.innerHTML = i;
                opg.innerHTML = i;
                opb.innerHTML = i;
                switch (i) {
                    case 100:
                        opb.selected = "selected";
                        break;
                    case 200:
                        opg.selected = "selected";
                        break;
                }
                gs.appendChild(opg);
                rs.appendChild(opr);
                bs.appendChild(opb);
            }
            setDiv();
        }

        function setDiv() {
            var font = document.getElementById("ctext").value;
            var dObj = document.getElementById("box");
            dObj.innerHTML = font;
        }

        function createData() {
            var font = document.getElementById("ctext").value;
            var r = rs.options[rs.selectedIndex].text;
            var g = gs.options[gs.selectedIndex].text;
            var b = bs.options[bs.selectedIndex].text;
            var type = document.getElementById("ctype").value;
            if (font == "" || font == "undefined") {
                font = "文字不能为空,使用默认文字";
                document.getElementById("ctext").value = font;
            }
            colorful('box', font, r, g, b, type);
        }

        function colorful(obj, font, r, g, b, type) {
            var boxObj;
            if (typeof (obj) == "string" || typeof (obj) == "number") {
                boxObj = document.getElementById(obj);
            } else {
                boxObj = obj;
            }
            boxObj.innerHTML = "<a href='#'>" + font + "</a>";
            var num = boxObj.getElementsByTagName("a")[0].scrollWidth;
            boxObj.innerHTML = "";
            for (var i = 0; i <= num; i++) {
                var j = i + 1;
                var c = Math.round(255 / num * i);
                switch (Number(type)) {
                    case 0:
                        r = c;
                        g = c;
                        b = c;
                        break;
                    case 1:
                        r = c;
                        break;
                    case 2:
                        g = c;
                        break;
                    case 3:
                        b = c;
                        break;
                }
                var iObj = document.createElement("A");
                iObj.innerHTML = font;
                iObj.style.clip = "rect(auto " + j + "px auto " + i + "px)";
                iObj.style.color = "rgb(" + r + "," + g + "," + b + ")";
                //iObj.href="#"; // 生成的文字超链接
                boxObj.appendChild(iObj);
            }
        }
        init();
    </script>
</body>

</html>

 

posted @ 2019-11-21 17:31  吴小明-  阅读(396)  评论(0编辑  收藏  举报