smarek / jquery-chained-selects
用于从分层JSON数据创建链式选择器的jQuery插件
v2.1.1
2023-09-13 07:43 UTC
Suggests
- components/jquery: Composer jQuery distribution, optional if you install by other means
README
用于使用分层javascript (JSON) 数据填充链式选择器的jQuery插件
示例用法
<form> <select id="sample-select"></select> </form> <script type="text/javascript"> var chainedData = { "A": { 1: "AA", 2: "AB" }, "B": { "BB": { 3: "BBB" } } }; $(document).ready(function () { $('#sample-select').chainedSelects({ data: chainedData, loggingEnabled: true }); }); </script>
完整选项
$("#select-id").chainedSelects({ placeholder: "", // placeholder text, can be left empty, default value is "", if the placeholder is empty, no empty option will be created selectCssClass: "my-select-extra-css-class", // extra css class to add on used/generated html select elements, defaults to `false` data: dataVariable, // data, can be function which returns data structure, or plain variable, defaults to `{}` maxLevels: 10, // to avoid browser hangs, by default is limited to 10 levels of hierarchy, you can raise this if you need to loggingEnabled: false, // enables internal logging, might be useful for debugging, defaults to `false` selectedKey: 3, // will pre-select options by option value, accepts numeric or string (string for selecting either category, number for the final option), default to `false` // IMPORTANT: selectedKey option will override defaultPath option defaultPath: ["B", "BB"], // will pre-select options by path, defaults to `false` sortByValue: false, // sort options by text value, defaults to `false` // IMPORTANT: if provided callback function fails, it will not report caught error if the `loggingEnabled` is not `true` onSelectedCallback: function(id){}, // will call user defined function with id of currently selected, or empty string if non-final option was chosen, defaults to `false` autoSelectSingleOptions: true, // will automatically select single options at any level (recursively), forcing user to make a choice only when there is choice to make, defaults to `false` });
API方法
// Set logging enabled (true or false, in case of invalid argument, defaults to true) $("#select-id").data("chainedSelects").setLoggingEnabled(boolean); // Change current selected key (integer or string, for either specific choice or category) $("#select-id").data("chainedSelects").changeSelectedKey(newSelectedKey);
使用说明
- 不允许选择父级,只能选择键为数字的值(在示例中只能选择1(AA)、2(AB)和3(BBB))
- 将绑定到围绕目标选择器的表单,并在表单提交之前,将具有选中值的虚拟选项放置到目标选择器中