網頁設計cxSelect 是基於jQuery 的多級聯動菜單插件,合用於省市、商品分類等聯動菜單。
列表數據通過AJAX 獲取,也可以自定義,數據內容利用JSON 花式。
同時兼容Zepto,便利在移動端使用。
國內省市縣數據起原:basecss/cityData Date: 2014.03.31
全球首要城市數據濫觞:收拾整頓國內常用網站和軟件Date: 2014.07.29
版本:jQuery的V1.7 +的Zepto V1.0 +jQuery的cxSelect V1.4.0
利用方式载入 JavaScript 文件
- <script src="jquery.js"></script>
- <script src="jquery.cxselect.js"></script>
複製代碼
DOM 结构
- <!--
- select 必须放在元素 id="element_id" 的内部,不限层级
- select 的 class 肆意取值,也能夠附加多个 class,如 class="province otherclass",在调用时只需要输入此中一个即可,但是不能重复
- -->
- <div id="element_id">
- <select class="province"></select>
- <select class="city"></select>
- <select class="area"></select>
- </div>
複製代碼
设置默认值
- <!-- 方式一:使用 option 的 value 和 selected 属性 -->
- <select class="province">
- <option value="浙江省" selected>浙江省</option>
- </select>
-
- <!-- 方式二:利用 select 的 data-value 属性 -->
- <select class="province" data-value="浙江省"></select>
複製代碼
调用
- $('#element_id').cxSelect({
- url: 'cityData.min.json', // 若是服务器不支撐 .json 类型文件,请将文件改为 .js 文件
- selects: ['province', 'city', 'area'], // 数组,请注意顺序
- emptyStyle: 'none'
- });
複製代碼
设置参数全局默认值
- // 需在引入 <script src="jquery.cxselect.js"></script> 之后,调用之前设置
- $.cxSelect.defaults.url = 'cityData.min.json';
- $.cxSelect.defaults.emptyStyle = 'none';
複製代碼
参数说明
名称
|
默认值
|
说明
|
selects |
[] |
下拉选框组。输入 select 的 className |
url |
null |
整合列表数据接口地址(URL)
每个选框的内容使用各自的接口地址,详见 [DEMO] |
data |
null |
自定义数据,类型为数组,数据使用 JSON 花樣。[DEMO] |
emptyStyle |
null |
子集无数据时 select 的状态。可设置为:"none"(display:none), "hidden"(visibility:hidden) |
required |
false |
是否为必选。设为 false 时,会在列表头部添加 <option value="firstValue">firstTitle</option> 选项。 |
firstTitle |
'请选择' |
选框第一个项目標标题(仅在 required 为 false 时有效) |
firstValue |
'' |
选框第一个项目的值(仅在 required 为 false 时有用) |
jsonSpace |
'' |
数据定名空间 |
jsonName |
'n' |
数据标题字段名称(用于 option 的标题) |
jsonValue |
'' |
数据值字段名称(用于 option 的 value,没有值字段时使用标题作为 value) |
jsonSub |
's' |
子集数据字段名称 |
data 属性参数在父元素上的 data- 属性
- <div id="element_id" data-url="cityData.min.json" data-selects="province,city,area" data-required="true"></div>
複製代碼
名称
|
说明
|
data-selects |
下拉选框组。输入 select 的 className,利用英文逗号分隔的字符串 |
data-url |
列表数据接口地址(此处只能设置 URL,自定义需要在参数中设置) |
data-empty-style |
子集无数据时 select 的状态 |
data-required |
是否为必选 |
data-first-title |
选框第一个项目的标题 |
data-first-value |
选框第一个项目標值 |
data-json-space |
数据定名空间 |
data-json-name |
数据标题字段名称 |
data-json-value |
数据值字段名称 |
data-json-sub |
子集数据字段名称 |
在 <select> 元素上的 data- 属性
- <select class="province" data-value="浙江省" data-required="false" data-first-title="选择省"></select>
複製代碼
名称
|
说明
|
data-value |
默认选中值 |
data-url |
列表数据接口地址 |
data-required |
是否为必选 |
data-query-name |
传递上一个选框值的参数名称(默认利用上一个选框的 name 属性值) |
data-first-title |
选框第一个项目標标题 |
data-first-value |
选框第一个项目標值 |
data-json-space |
数据定名空间 |
data-json-name |
数据标题字段名称 |
data-json-value |
数据值字段名称 |
API 接口
- var cxSelectApi;
- // 方式一:
- cxSelectApi = $.cxSelect($('#element_id'), {
- selects: ['province', 'city', 'area']
- });
-
- // 方式二:
- $('#element_id').cxSelect({
- selects: ['province', 'city', 'area']
- }, function(api) {
- cxSelectApi = api;
- });
複製代碼
名称
|
说明
|
attach() |
绑定
调用时会自动进行绑定,用于使用detach消除绑定后,进行從頭绑定。 |
detach() |
消除绑定
消除绑定后,不再具有联动結果。 |
clear(index) |
清空选项
清空第 index 个 select 本身及之后的 select 的选项。
index: select 的序号,从 0 开始。 |
setOptions(settings) |
從頭设置参数settings: 与调用时参数一致。 |
測試代碼:
- <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
- <html xmlns="http://www.w3.org/1999/xhtml">
- <head>
- <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
- <title>無題目文件</title>
- </head>
-
- <body>
- <?php
- include_once ('global.php');
- if (isset($_POST['update'])) {
- //更新資料庫
- $country = $_POST["country"];
- $state = addslashes($_POST["state"]);
- $city = addslashes($_POST["city"]);
- $region = addslashes($_POST["region"]);
-
- $sql = "INSERT INTO net_area(country,state,city,region) VALUES('$country','$state','$city','$region')";
- /*echo $sql = "UPDATE net_config SET
- country ='$country',
- state = '$state',
- city = '$city',
- region = '$region'";*/
- if (@mysql_query($sql)) {
- echo '<script>alert(\'新增完成!\');window.location=\'index1.php\';</script>';
- } else {
- echo '<script>alert(\'新增失敗!\');window.location=\'index1.php\';</script>';
- }
-
- }
- $sql = @mysql_query("SELECT * FROM net_area WHERE aid='9'");
- $row = mysql_fetch_array($sql);
- $country = $row[country];
- $state = $row[state];
- $city = $row[city];
- $region = $row[region];
- ?>
- <form action="<?php $_SERVER['PHP_SELF'] ?>" method="post">
- <div class="wrap">
- <h1>cxSelect 联动下拉菜单</h1>
-
- <div id="global_location">
-
- <legend>全球首要国家城市联动</legend>
- <p>地點地区:
- <select class="country" data-first-title="选择国家" required></select>
- <select class="state" data-required="true"></select>
- <select class="city" data-required="true"></select>
- <select class="region" data-required="true" name="area"></select>
- </p>
- </div>
- <button class="btn btn-primary" type="reset" name="reset">重新輸入</button> <button class="btn btn-success" type="submit" name="update">送出資料</button>
-
-
- </div>
- </form>
- <script src="http://cdn.staticfile.org/jquery/1.11.3/jquery.min.js"></script>
- <script src="js/jquery.cxselect.js"></script>
- <script>
- (function() {
-
- var urlGlobal = 'js/globalData.min.json';
-
- // 全球主要国家城市联动
- $('#global_location').cxSelect({
- url: urlGlobal,
- selects: ['country', 'state', 'city', 'region'],
- emptyStyle: 'none',
-
- });
-
-
-
- })();
- </script>
-
- </body>
- </html>
複製代碼
global.php為MYSQL文件根基連線資料庫資訊
該段落改成
為資料庫撈出之預設值
- data-value="<?php echo $country?>"
複製代碼
本來
載入預設值
參考文章
http://code.ciaoca.com/jquery/cxSelect/
http://www.eshejie.com/effects/html/9.html
引用自:
留言列表