多选插件JS源码。

2024-06-06 15:58
文章标签 源码 js 插件 多选

本文主要是介绍多选插件JS源码。,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

/**
 * 基于JQUERY的自定义插件 多选频率插件 
 */
(function(){
//基础数据
var datas = [{name:"week",title:"周 频 率",colNumber:7,data:[
{name:"周一",value:'1'},
{name:'周二',value:'2'},
{name:'周三',value:'3'},
{name:'周四',value:'4'},
{name:'周五',value:'5'},
{name:'周六',value:'6'},
{name:'周日',value:'0'}
]},
{name:"month",title:"月 频 率",colNumber:7,data:[
{name:'1 号',value:'1'},
{name:'2 号',value:'2'},
{name:'3 号',value:'3'},
{name:'4 号',value:'4'},
{name:'5 号',value:'5'},
{name:'6 号',value:'6'},
{name:'7 号',value:'7'},
{name:'8 号',value:'8'},
{name:'9 号',value:'9'},
{name:'10号',value:'10'},
{name:'11号',value:'11'},
{name:'12号',value:'12'},
{name:'13号',value:'13'},
{name:'14号',value:'14'},
{name:'15号',value:'15'},
{name:'16号',value:'16'},
{name:'17号',value:'17'},
{name:'18号',value:'18'},
{name:'19号',value:'19'},
{name:'20号',value:'20'},
{name:'21号',value:'21'},
{name:'22号',value:'22'},
{name:'23号',value:'23'},
{name:'24号',value:'24'},
{name:'25号',value:'25'},
{name:'27号',value:'27'},
{name:'28号',value:'28'},
{name:'29号',value:'29'},
{name:'30号',value:'30'},
{name:'31号',value: '31'}
]}];
/*
* 验证参数是否合法
*/
function vlidateFrequencyOptions(options){
//FORM中的隐藏域的Name
if(!('name' in options)){
return "'name' in options is false!";
}
//频率类型 基础数据中的Name
if (!("frequencyType" in options)) {
return "'frequencyType' in options is false!";
}
var isExit = false;
$.each($(datas),function(i,item){
if (item.name==options.frequencyType) {
isExit = true;
}
})
if (!isExit) {
return "'"+options.frequencyType+"' is undefined !";
}
return null;
}

/**
* 视图
*/
function initView(options,top,left,id){
//移除保存的所有hidee标签
$(".FrequencyHiddenName").remove();
//装载基础数据
var data = null;
$.each($(datas),function(i,item){
if (item.name==options.frequencyType) {
data = item;
}
});
if(typeof($("#Frequency_"+id).html())==="undefined"){
//创建新的
var html ="<div Frequency='true'  id='Frequency_"+id+"' style='background:white;border:1px solid #DDDDDD;position:absolute;top:"+(top+32)+"px;left:"+(left-1)+"px'>";
html += "<table Frequency='true' style=' background:white;width:300px;margin-left:10px;margin-right:10px; margin-bottom:10px'>";
html += "<thead Frequency='true' ><tr Frequency='true' style='height:40px;'><td align='center' colspan='"+data.colNumber+"'>"+data.title+"</td></tr></thead><tbody>";
$.each($(data.data),function(i,item){
if(i==0){
html += "<tr style='height:30px;' Frequency='true'>";
}
if(i!=0&&i%data.colNumber==0){
html += "</tr><tr Frequency='true'>";
}
html += "<td Frequency='true' class="+options.frequencyType+" value='"+item.value+"' style='height:30px;border:1px solid #DDDDDD' align='center'>"+item.name+"</td>";
});
html += "</tr></tbody></table></div>";
$("body").append(html);
}else{
//替换内容
var html = "<table Frequency='true' style=' background:white;width:300px;margin-left:10px;margin-right:10px; margin-bottom:10px'>";
html += "<thead Frequency='true' ><tr Frequency='true' style='height:40px;'><td align='center' colspan='"+data.colNumber+"'>"+data.title+"</td></tr></thead><tbody>";
$.each($(data.data),function(i,item){
if(i==0){
html += "<tr style='height:30px;' Frequency='true'>";
}
if(i!=0&&i%data.colNumber==0){
html += "</tr><tr Frequency='true'>";
}
html += "<td Frequency='true' class="+options.frequencyType+" value='"+item.value+"' style='height:30px;border:1px solid #DDDDDD' align='center'>"+item.name+"</td>";
});
html += "</tr></tbody></table>";
$("#Frequency_"+id).html(html);
}
//单击事件
$("#Frequency_"+id+" ."+options.frequencyType).each(function(i,item){
$(item).css({"cursor":"hand"});
$(item).click(function(){
if(typeof($(this).attr("ckecked"))==="undefined"){
$(this).attr("ckecked","true");
$(this).css({"background":"#D2E9FF"});
//新增参数
$("#"+id).after("<input type='hidden' class='FrequencyHiddenName' name='"+options.name+"' value='"+$(this).attr("value")+"'/>");
}else{
$(this).removeAttr("ckecked");
$(this).css({"background":"white"});
var parent = $("#"+id).parent();
//移除参数
$("#"+id).parent().find("input[value='"+$(this).attr("value")+"'].FrequencyHiddenName").remove();
}
});
});
//填充空白
var len = $("#Frequency_"+id+" tr:last td").length;
if(len<data.colNumber){
for(var i = 0;i<(data.colNumber-len);i++){
$("#Frequency_"+id+" tr:last").append("<td style='height:30px;border:1px solid #DDDDDD' align='center'><span>&nbsp;</span></td>");
}
}
//第一次加载 设置默认值
if (('soure' in options) && options.soure!="") {
var values = options.soure.split(",");
for ( var j = 0; j < values.length; j++){
$("#Frequency_"+id+" ."+options.frequencyType).each(function(i,item){
if (values[j]==$(item).attr("value")) {
//选中
$(item).click();
}
});
}
}
}
//获取元素的绝对坐标
function getElemPos(obj){
        var pos = {"top":0, "left":0};
        if (obj.offsetParent){
            while (obj.offsetParent){
      pos.top += obj.offsetTop;
            pos.left += obj.offsetLeft;
            obj = obj.offsetParent;
        }
         }else if(obj.x){
            pos.left += obj.x;
         }else if(obj.x){
            pos.top += obj.y;
         }
         return pos;
}


/**
* 初始化函数
* options JSON对象 
*/
$.fn.Frequency = function (options){
//校验参数
var vlidateMsg = vlidateFrequencyOptions(options);
if (vlidateMsg!=null) {
alert(vlidateMsg);
return;
}
//获取坐标
var pos =(getElemPos($(this)[0]));
//获得事件源的元素的编号
var id = $(this).attr("id");
//视图 
initView(options,pos.top,pos.left,id);
//隐藏事件
/*$("body *").click(function(e){
var isFrequency = typeof($(this).attr("frequency"));
var isEventTarget = typeof(e.target);
//如果单击的不是频率选项并且不是本JS生成的 都不隐藏  
if ((isFrequency==="undefined")&&(isEventTarget=="undefined"||e.target.id != id)) {
$("#Frequency_"+id).hide();
}else{
$("#Frequency_"+id).show();
}
}); */
}
})();

这篇关于多选插件JS源码。的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1036568

相关文章

JS纯前端实现浏览器语音播报、朗读功能的完整代码

《JS纯前端实现浏览器语音播报、朗读功能的完整代码》在现代互联网的发展中,语音技术正逐渐成为改变用户体验的重要一环,下面:本文主要介绍JS纯前端实现浏览器语音播报、朗读功能的相关资料,文中通过代码... 目录一、朗读单条文本:① 语音自选参数,按钮控制语音:② 效果图:二、朗读多条文本:① 语音有默认值:②

在Node.js中使用.env文件管理环境变量的全过程

《在Node.js中使用.env文件管理环境变量的全过程》Node.js应用程序通常依赖于环境变量来管理敏感信息或配置设置,.env文件已经成为一种流行的本地管理这些变量的方法,本文将探讨.env文件... 目录引言为什么使php用 .env 文件 ?如何在 Node.js 中使用 .env 文件最佳实践引

使用Node.js和PostgreSQL构建数据库应用

《使用Node.js和PostgreSQL构建数据库应用》PostgreSQL是一个功能强大的开源关系型数据库,而Node.js是构建高效网络应用的理想平台,结合这两个技术,我们可以创建出色的数据驱动... 目录初始化项目与安装依赖建立数据库连接执行CRUD操作查询数据插入数据更新数据删除数据完整示例与最佳

java 恺撒加密/解密实现原理(附带源码)

《java恺撒加密/解密实现原理(附带源码)》本文介绍Java实现恺撒加密与解密,通过固定位移量对字母进行循环替换,保留大小写及非字母字符,由于其实现简单、易于理解,恺撒加密常被用作学习加密算法的入... 目录Java 恺撒加密/解密实现1. 项目背景与介绍2. 相关知识2.1 恺撒加密算法原理2.2 Ja

Nginx屏蔽服务器名称与版本信息方式(源码级修改)

《Nginx屏蔽服务器名称与版本信息方式(源码级修改)》本文详解如何通过源码修改Nginx1.25.4,移除Server响应头中的服务类型和版本信息,以增强安全性,需重新配置、编译、安装,升级时需重复... 目录一、背景与目的二、适用版本三、操作步骤修改源码文件四、后续操作提示五、注意事项六、总结一、背景与

Android实现图片浏览功能的示例详解(附带源码)

《Android实现图片浏览功能的示例详解(附带源码)》在许多应用中,都需要展示图片并支持用户进行浏览,本文主要为大家介绍了如何通过Android实现图片浏览功能,感兴趣的小伙伴可以跟随小编一起学习一... 目录一、项目背景详细介绍二、项目需求详细介绍三、相关技术详细介绍四、实现思路详细介绍五、完整实现代码

Three.js构建一个 3D 商品展示空间完整实战项目

《Three.js构建一个3D商品展示空间完整实战项目》Three.js是一个强大的JavaScript库,专用于在Web浏览器中创建3D图形,:本文主要介绍Three.js构建一个3D商品展... 目录引言项目核心技术1. 项目架构与资源组织2. 多模型切换、交互热点绑定3. 移动端适配与帧率优化4. 可

RabbitMQ 延时队列插件安装与使用示例详解(基于 Delayed Message Plugin)

《RabbitMQ延时队列插件安装与使用示例详解(基于DelayedMessagePlugin)》本文详解RabbitMQ通过安装rabbitmq_delayed_message_exchan... 目录 一、什么是 RabbitMQ 延时队列? 二、安装前准备✅ RabbitMQ 环境要求 三、安装延时队

Spring Boot Maven 插件如何构建可执行 JAR 的核心配置

《SpringBootMaven插件如何构建可执行JAR的核心配置》SpringBoot核心Maven插件,用于生成可执行JAR/WAR,内置服务器简化部署,支持热部署、多环境配置及依赖管理... 目录前言一、插件的核心功能与目标1.1 插件的定位1.2 插件的 Goals(目标)1.3 插件定位1.4 核

java使用protobuf-maven-plugin的插件编译proto文件详解

《java使用protobuf-maven-plugin的插件编译proto文件详解》:本文主要介绍java使用protobuf-maven-plugin的插件编译proto文件,具有很好的参考价... 目录protobuf文件作为数据传输和存储的协议主要介绍在Java使用maven编译proto文件的插件