您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
jQuery Plugin For Checkable Images. https://www.jqueryscript.net/other/jQuery-Plugin-For-Checkable-Images-imgCheckbox.html
此脚本不应直接安装。它是供其他脚本使用的外部库,要使用该库请加入元指令 // @require https://update.gf.qytechs.cn/scripts/430180/956211/imgCheckbox2.js
/* * imgCheckbox * description: jQuery Plugin For Checkable Images. https://www.jqueryscript.net/other/jQuery-Plugin-For-Checkable-Images-imgCheckbox.html * Version: 0.5.4 * License: GPLv2 * Author: James Cuénod * */ (function($) { var CHK_TOGGLE = 0; var CHK_SELECT = 1; var CHK_DESELECT = 2; var CHECKMARK_POSITION = { "top-left": { "top": "0.5%", "left": "0.5%", }, "top": { "top": "0.5%", "left": 0, "right": 0, "margin": "auto", }, "top-right": { "top": "0.5%", "right": "0.5%", }, "left": { "left": "0.5%", "bottom": 0, "top": 0, "margin": "auto", }, "right": { "right": "0.5%", "bottom": 0, "top": 0, "margin": "auto", }, "bottom-left": { "bottom": "0.5%", "left": "0.5%", }, "bottom": { "bottom": "0.5%", "left": 0, "right": 0, "margin": "auto", }, "bottom-right": { "bottom": "0.5%", "right": "0.5%", }, "center": { "top": "0.5%", "bottom": "0.5%", "left": "0.5%", "right": "0.5%", "margin": "auto", }, }; var imgCheckboxClass = function(element, options, id) { var $wrapperElement, $finalStyles = {}, grayscaleStyles = { "span.imgCheckbox img": { "transform": "scale(1)", "filter": "none", "-webkit-filter": "grayscale(0)", }, "span.imgCheckbox.imgChked img": { // "filter": "gray", //TODO - this line probably will not work but is necessary for IE "filter": "grayscale(1)", "-webkit-filter": "grayscale(1)", } }, scaleStyles = { "span.imgCheckbox img": { "transform": "scale(1)", }, "span.imgCheckbox.imgChked img": { "transform": "scale(0.9)", } }, scaleCheckMarkStyles = { "span.imgCheckbox::before": { "transform": "scale(0)", }, "span.imgCheckbox.imgChked::before": { "transform": "scale(1)", } }, fadeCheckMarkStyles = { "span.imgCheckbox::before": { "opacity": "0", }, "span.imgCheckbox.imgChked::before": { "opacity": "1", } }; /* *** STYLESHEET STUFF *** */ // shove in the custom check mark if (options.checkMarkImage !== false) $.extend(true, $finalStyles, { "span.imgCheckbox::before": { "background-image": "url('" + options.checkMarkImage + "')" }}); // give the checkmark dimensions var chkDimensions = options.checkMarkSize.split(" "); $.extend(true, $finalStyles, { "span.imgCheckbox::before": { "width": chkDimensions[0], "height": chkDimensions[chkDimensions.length - 1] }}); // give the checkmark a position $.extend(true, $finalStyles, { "span.imgCheckbox::before": CHECKMARK_POSITION [ options.checkMarkPosition ] }); // fixed image sizes if (options.fixedImageSize) { var imgDimensions = options.fixedImageSize.split(" "); $.extend(true, $finalStyles,{ "span.imgCheckbox img": { "width": imgDimensions[0], "height": imgDimensions[imgDimensions.length - 1] }}); } var conditionalExtend = [ { doExtension: options.graySelected, style: grayscaleStyles }, { doExtension: options.scaleSelected, style: scaleStyles }, { doExtension: options.scaleCheckMark, style: scaleCheckMarkStyles }, { doExtension: options.fadeCheckMark, style: fadeCheckMarkStyles } ]; conditionalExtend.forEach(function(extension) { if (extension.doExtension) $.extend(true, $finalStyles, extension.style); }); $finalStyles = $.extend(true, {}, defaultStyles, $finalStyles, options.styles); // Now that we've built up our styles, inject them injectStylesheet($finalStyles, id); /* *** DOM STUFF *** */ element.wrap("<span class='imgCheckbox" + id + "'>"); $wrapperElement = element.parent(); // set up select/deselect functions $wrapperElement.each(function() { var $that = $(this); $(this).data("imgchk.deselect", function(){ changeSelection($that, CHK_DESELECT, options.addToForm, options.radio, options.canDeselect, $wrapperElement); }).data("imgchk.select", function(){ changeSelection($that, CHK_SELECT, options.addToForm, options.radio, options.canDeselect, $wrapperElement); }); $(this).children().first().data("imgchk.deselect", function(){ changeSelection($that, CHK_DESELECT, options.addToForm, options.radio, options.canDeselect, $wrapperElement); }).data("imgchk.select", function(){ changeSelection($that, CHK_SELECT, options.addToForm, options.radio, options.canDeselect, $wrapperElement); }); }); // preselect elements if (options.preselect === true || options.preselect.length > 0) { $wrapperElement.each(function(index) { if (options.preselect === true || options.preselect.indexOf(index) >= 0) $(this).addClass("imgChked"); }); } // set up click handler $wrapperElement.click(function() { var el = $(this); changeSelection(el, CHK_TOGGLE, options.addToForm, options.radio, options.canDeselect, $wrapperElement); if (options.onclick) options.onclick(el); }); /* *** INJECT INTO FORM *** */ if (options.addToForm instanceof jQuery || options.addToForm === true) { if (options.addToForm === true) { options.addToForm = $(element).closest("form"); } if (options.addToForm.length === 0) { if (options.debugMessages) console.log("imgCheckbox: no form found (looks for form by default)"); options.addToForm = false; } } if (options.addToForm !== false) { $(element).each(function(index) { var hiddenElementId = "hEI" + id + "-" + index; $(this).parent().data('hiddenElementId', hiddenElementId); var imgName = $(this).attr("name"); imgName = (typeof imgName != "undefined") ? imgName : $(this).attr("src").match(/\/(.*)\.[\w]+$/)[1]; $('<input />').attr('type', 'checkbox') .attr('name', imgName) .addClass(hiddenElementId) .css("display", "none") .prop("checked", $(this).parent().hasClass("imgChked")) .appendTo(options.addToForm); }); } return this; }; /* CSS Injection */ function injectStylesheet(stylesObject, id) { // Create a blank style var style = document.createElement("style"); // WebKit hack style.appendChild(document.createTextNode("")); // Add the <style> element to the page document.head.appendChild(style); var stylesheet = document.styleSheets[document.styleSheets.length - 1]; for (var selector in stylesObject) { if (stylesObject.hasOwnProperty(selector)) { compatInsertRule(stylesheet, selector, buildRules(stylesObject[selector]), id); } } } function buildRules(ruleObject) { var ruleSet = ""; for (var property in ruleObject) { if (ruleObject.hasOwnProperty(property)) { ruleSet += property + ":" + ruleObject[property] + ";"; } } return ruleSet; } function compatInsertRule(stylesheet, selector, cssText, id) { var modifiedSelector = selector.replace(".imgCheckbox", ".imgCheckbox" + id); // IE8 uses "addRule", everyone else uses "insertRule" if (stylesheet.insertRule) { stylesheet.insertRule(modifiedSelector + '{' + cssText + '}', 0); } else { stylesheet.addRule(modifiedSelector, cssText, 0); } } function changeSelection($chosenElement, howToModify, addToForm, radio, canDeselect, $wrapperElement) { if (radio && howToModify !== CHK_DESELECT) { $wrapperElement.not($chosenElement).removeClass("imgChked"); if (canDeselect) { $chosenElement.toggleClass("imgChked"); } else { $chosenElement.addClass("imgChked"); } } else { switch (howToModify) { case CHK_DESELECT: $chosenElement.removeClass("imgChked"); break; case CHK_TOGGLE: $chosenElement.toggleClass("imgChked"); break; case CHK_SELECT: $chosenElement.addClass("imgChked"); break; } } if (addToForm) updateFormValues(radio ? $wrapperElement : $chosenElement); } function updateFormValues($element) { $element.each(function() { $( "." + $(this).data("hiddenElementId") ).prop("checked", $(this).hasClass("imgChked")); }); } /* Init */ $.fn.imgCheckbox = function(options) { if ($(this).data("imgCheckboxId")) //already initialised: old instance = $.fn.imgCheckbox.instances[$(this).data("imgCheckboxId") - 1]; return this; else { var optionsWithDefaults = $.extend(true, {}, $.fn.imgCheckbox.defaults, options); var $that = new imgCheckboxClass($(this), optionsWithDefaults, $.fn.imgCheckbox.instances.length); $(this).data("imgCheckboxId", $.fn.imgCheckbox.instances.push($that)); if (optionsWithDefaults.onload) optionsWithDefaults.onload(); return this; } }; $.fn.deselect = function() { if (this.data("imgchk.deselect")) { this.data("imgchk.deselect")(); } return this; }; $.fn.select = function() { if (this.data("imgchk.select")) { this.data("imgchk.select")(); } return this; }; $.fn.imgCheckbox.instances = []; $.fn.imgCheckbox.defaults = { "checkMarkImage": "", "graySelected": true, "scaleSelected": true, "fixedImageSize": false, "checkMarkSize": "30px", "checkMarkPosition": "top-left", "scaleCheckMark": true, "fadeCheckMark": false, "addToForm": true, "preselect": [], "radio": false, "canDeselect": false, "onload": false, "onclick": false, "debugMessages": false, }; var defaultStyles = { "span.imgCheckbox img": { "display": "block", "margin": "0", "padding": "0", "transition-duration": "300ms", }, "span.imgCheckbox.imgChked img": { }, "span.imgCheckbox": { "user-select": "none", "-webkit-user-select": "none", /* Chrome all / Safari all */ "-moz-user-select": "none", /* Firefox all */ "-ms-user-select": "none", /* IE 10+ */ "position": "relative", "padding": "0", "margin": "5px", "display": "inline-block", "border": "1px solid transparent", "transition-duration": "300ms", }, "span.imgCheckbox.imgChked": { "border-color": "#ccc", }, "span.imgCheckbox::before": { "display": "block", "background-size": "100% 100%", "content": "''", "color": "white", "font-weight": "bold", "border-radius": "50%", "position": "absolute", "margin": "0.5%", "z-index": "1", "text-align": "center", "transition-duration": "300ms", }, "span.imgCheckbox.imgChked::before": { } }; })( jQuery );
QingJ © 2025
镜像随时可能失效,请加Q群300939539或关注我们的公众号极客氢云获取最新地址