jQuery CSS3自定义美化Checkbox实现代码

前端之家收集整理的这篇文章主要介绍了jQuery CSS3自定义美化Checkbox实现代码前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

效果图:

是不是比默认的好看多了,个人的审美观应该还是可以的。

接下来我们一起来看看实现这款美化版CheckBox的源代码

主要思路

是利用隐藏原来的checkBox和radioBox,用一个div来模拟checkBox/radioBox,并使用jQuery来完成选择切换时的动画效果

先来看看HTML代码

  • Gender:

  • Male
  • Female
    • 推荐网站:

    • 何问起
    • 柯乐义
    • hwq2.com
    • hovertree.net

    然后我们用jQuery代码来为每一个checkBox和radioBox创建一个div,这个div的classname为check-Box和radio-btn。

    dio-btn"]").wrap("

    dio-btn">
    "); $("input[name="check-Box"]").wrap("
    Box">
    ");

    那么我们接下来要让原来的checkBox隐藏,同时设置模拟div的样式:

    dio-btn input[type="radio"],.check-Box input[type="checkBox"] { visibility: hidden; }

    .check-Box {
    width: 22px;
    height: 22px;
    cursor: pointer;
    display: inline-block;
    margin: 2px 7px 0 0;
    position: relative;
    overflow: hidden;
    Box-shadow: 0 0 1px #ccc;
    -webkit-border-radius: 3px;
    -moz-border-radius: 3px;
    border-radius: 3px;
    background: rgb(255,255,255);
    background: -moz-linear-gradient(top,rgba(255,1) 0%,rgba(246,246,1) 47%,rgba(237,237,1) 100%);
    background: -webkit-gradient(linear,left top,left bottom,color-stop(0%,1)),color-stop(47%,color-stop(100%,1)));
    background: -webkit-linear-gradient(top,1) 100%);
    background: -o-linear-gradient(top,1) 100%);
    background: -ms-linear-gradient(top,1) 100%);
    background: linear-gradient(to bottom,1) 100%);
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr="#ffffff",endColorstr="#ededed",GradientType=0);
    border: 1px solid #ccc;
    }
    .check-Box i {
    background: url("http://hovertree.com/texiao/html5/32/css/check_mark.png") no-repeat center center;
    position: absolute;
    left: 3px;
    bottom: -15px;
    width: 16px;
    height: 16px;
    opacity: .5;
    -webkit-transition: all 400ms ease-in-out;
    -moz-transition: all 400ms ease-in-out;
    -o-transition: all 400ms ease-in-out;
    transition: all 400ms ease-in-out;
    -webkit-transform:rotateZ(-180deg);
    -moz-transform:rotateZ(-180deg);
    -o-transform:rotateZ(-180deg);
    transform:rotateZ(-180deg);
    }
    .checkedBox {
    -moz-Box-shadow: inset 0 0 5px 1px #ccc;
    -webkit-Box-shadow: inset 0 0 5px 1px #ccc;
    Box-shadow: inset 0 0 5px 1px #ccc;
    border-bottom-color: #fff;
    }
    .checkedBox i {
    bottom: 2px;
    -webkit-transform:rotateZ(0deg);
    -moz-transform:rotateZ(0deg);
    -o-transform:rotateZ(0deg);
    transform:rotateZ(0deg);
    }
    /Custom radio button/
    .radio-btn {
    width: 20px;
    height: 20px;
    display: inline-block;
    float: left;
    margin: 3px 7px 0 0;
    cursor: pointer;
    position: relative;
    -webkit-border-radius: 100%;
    -moz-border-radius: 100%;
    border-radius: 100%;
    border: 1px solid #ccc;
    Box-shadow: 0 0 1px #ccc;
    background: rgb(255,GradientType=0);
    }
    .checkedRadio {
    -moz-Box-shadow: inset 0 0 5px 1px #ccc;
    -webkit-Box-shadow: inset 0 0 5px 1px #ccc;
    Box-shadow: inset 0 0 5px 1px #ccc;
    }
    .radio-btn i {
    border: 1px solid #E1E2E4;
    width: 10px;
    height: 10px;
    position: absolute;
    left: 4px;
    top: 4px;
    -webkit-border-radius: 100%;
    -moz-border-radius: 100%;
    border-radius: 100%;
    }
    .checkedRadio i {
    background-color: #898A8C;
    }/ 何问起 hovertree.com /

    上面这段CSS3代码就是用样式来自定义div,让div的样式和checkBox和radioBox一样。

    最后我们来模拟点击选中和取消选中,这部分也是用jQuery来实现:

    dio-btn").on("click",function () { var _this = $(this),block = _this.parent().parent(); block.find("input:radio").attr("checked",false); block.find(".radio-btn").removeClass("checkedRadio"); _this.addClass("checkedRadio"); _this.find("input:radio").attr("checked",true); });

    $.fn.toggleCheckBox = function () {
    this.attr("checked",!this.attr("checked"));
    }
    $(".check-Box").on("click",function () {
    $(this).find(":checkBox").toggleCheckBox();
    $(this).toggleClass("checkedBox");
    });/ 何问起 hovertree.com /

    以上就是本文的全部内容,希望对大家学习jquery程序设计有所帮助。

    猜你在找的jQuery相关文章