js二级联动院系

参考于https://blog.csdn.net/donghaiming111/article/details/80840089

<!DOCTYPE html>
<html>
<head>
    <title>某高校</title>
   <script type="text/javascript" src="selectDepartment.js"></script>
</head>
<body>
<div>
<div>
院:<select id="cmbCollege"></select>
</div>
<div>
系:<select id="cmbDepartment"></select>
</div>
<script>
departmentInit('cmbCollege', 'cmbDepartment', '软件学院', '软件工程');
</script>
</div>
</body>
</html>

 

selectDepartment.js

function departmentInit(_cmbCollege, _cmbDepartment, defaultCollege, defaultDepartment) {
        var cmbCollege = document.getElementById(_cmbCollege);
    var cmbDepartment = document.getElementById(_cmbDepartment);
    function cmbSelect(cmb, str) {
        for (var i = 0; i < cmb.options.length; i++) {
            if (cmb.options[i].value == str) {
                cmb.selectedIndex = i;
                return;
            }
        }
    }
    function cmbAddOption(cmb, str, obj) {
        var option = document.createElement("OPTION");
        cmb.options.add(option);
        option.innerHTML = str;
        option.value = str;
        option.obj = obj;
    }

    function changeCollege() {
        cmbDepartment.options.length = 0;
        cmbDepartment.onchange = null;
        if (cmbCollege.selectedIndex == -1) return;
        var item = cmbCollege.options[cmbCollege.selectedIndex].obj;
        for (var i = 0; i < item.DepartmentList.length; i++) {
            cmbAddOption(cmbDepartment, item.DepartmentList[i].name, item.DepartmentList[i]);
        }
        cmbSelect(cmbDepartment, defaultDepartment);
    }




    for (var i = 0; i < CollegeList.length; i++) {
        cmbAddOption(cmbCollege, CollegeList[i].name, CollegeList[i]);
    }
    cmbSelect(cmbCollege, defaultCollege);
    changeCollege();
    cmbCollege.onchange = changeCollege;
    return;
}

var CollegeList = [
    {
        name: ' 哲学社会学学院', DepartmentList: [{ name: '哲学' }, { name: '伦理学' }, { name: '社会学' }, { name: '社会工作' }, { name: '教育学' }, { name: '学前教育' }]
    },
    {
        name: ' 经济与管理学院', DepartmentList: [{ name: '经济学' }, { name: '国际经济与贸易' }, { name: '金融学' }, { name: '经济统计学  ' }, { name: '工商管理' }, { name: '信息管理与信息系统' }, { name: '电子商务' }, { name: '会计学' }, { name: '酒店管理' }, { name: '物业管理' }, { name: '图书馆学' }]
    },
    {
        name: ' 法学院', DepartmentList: [{ name: '法学' }, { name: '知识产权' }]
    },
    {
        name: ' 政治与公共管理学院', DepartmentList: [{ name: '国际政治' }, { name: '思想政治教育' }, { name: '政治学与行政学 ' }, { name: '行政管理' }, { name: '劳动与社会保障' }]
    },
    {
        name: ' 体育学院', DepartmentList: [{ name: '体育教育' }, { name: '运动训练' }, { name: '社会体育指导与管理 ' }, { name: '武术与民族传统体育  ' }]
    },
    {
        name: ' 文学院', DepartmentList: [{ name: '汉语言文学' }, { name: '汉语国际教育' }, { name: '书法学  ' }, { name: '新闻学' }, { name: '广告学  ' }, { name: '戏剧影视文学' }]
    },
    {
        name: ' 外语学院', DepartmentList: [{ name: '英语' }, { name: '俄语' }, { name: '德语  ' }, { name: '日语  ' }, { name: '翻译  ' }]
    },
    {
        name: ' 美术学院', DepartmentList: [{ name: '绘画' }, { name: '雕塑  ' }, { name: '艺术设计' }, { name: '公共艺术' }, { name: '数字媒体艺术' }, { name: '视觉传达设计 ' }, { name: '环境设计' }]
    },
    {
        name: ' 音乐学院', DepartmentList: [{ name: '音乐学' }, { name: '作曲与作曲技术理论' }, { name: '音乐表演' }, { name: '舞蹈编导  ' }]
    },
    {
        name: ' 历史文化学院', DepartmentList: [{ name: '历史学' }, { name: '考古学' }, { name: '博物馆学' }, { name: '旅游管理' }]
    },
    {
        name: ' 数学科学学院', DepartmentList: [{ name: '数学与应用数学' }, { name: '信息与计算科学' }, { name: '统计学' }]
    },
    {
        name: ' 化学化工学院', DepartmentList: [{ name: '化学' }, { name: '应用化学' }, { name: '材料化学' }, { name: '药学' }]
    },
    {
        name: ' 生命科学学院', DepartmentList: [{ name: '自然地理与资源环境' }, { name: '资源环境与城乡规划管理' }, { name: '食品科学与工程' }, { name: '生物工程' }]
    },
    {
        name: ' 物理电子工程学院', DepartmentList: [{ name: '电子信息科学与技术' }, { name: '光信息科学与技术' }, { name: '材料物理' }, { name: '电子科学与技术' }]
    },
    {
        name: ' 环境与资源学院', DepartmentList: [{ name: '环境科学' }, { name: '环境生态工程' }, { name: '环境工程' }]
    },
    {
        name: ' 教育科学学院', DepartmentList: [{ name: '应用心理学' }]
    },
    {
        name: ' 电子信息工程系', DepartmentList: [{ name: '电子信息工程' }]
    },
    {
        name: ' 计算机与信息技术学院', DepartmentList: [{ name: '计算机科学与技术' }, { name: '计算机科学与技术(大数据方向)' }, { name: '数据科学与大数据技术' }]
    },
    {
        name: ' 软件学院', DepartmentList: [{ name: '软件工程' }]
    },
    {
        name: ' 自动化系', DepartmentList: [{ name: '测控技术与仪器' }, { name: '电气工程及其自动化' }, { name: '自动化' }]
    },
    {
        name: ' 土木工程系', DepartmentList: [{ name: '土木工程' }, { name: '建筑学' }]
    },
    {
        name: ' 电力工程系', DepartmentList: [{ name: '建筑环境与能源应用工程' }, { name: '建筑电气与智能化' }, { name: '机械电子工程' }]
    },
    {
        name: ' 动力工程系', DepartmentList: [{ name: '能源与动力工程' }, { name: '新能源科学与工程' }]
    },
    {
        name: ' 工程管理系', DepartmentList: [{ name: '工程管理' }, { name: '工程造价' }]
    }
];

 

测试结果

C++实现生产js

#include<iostream>
#include<algorithm>
#include<string>
#include<fstream>
#include<stack>
#include<list>
using namespace std;
struct node
{
	string college;
	list<string> department;
};
list<node *>l;
list<string>ls;
string Json;
void LoadContext()
{
	ifstream f("json.txt");
	string str;

	while (!f.eof())
	{
		getline(f,str);
		ls.push_back(str);
	}
	f.close();
}
void LoadList()
{
	string StrSeparator = "  ";
	int size_pos ;
	int prev_pos;
	string str;
	stack<string>st;
	string temp;
	while (ls.size())
	{
		size_pos = 0;
		prev_pos=0;
		str = ls.back();
		int string_len = str.length();
		while ((size_pos = str.find_first_of(StrSeparator, size_pos+2)) != - 1)
		{
			
			temp = str.substr(prev_pos, size_pos- prev_pos);
			st.push(temp);
			//cout << temp;
			prev_pos = size_pos+2;
			temp.clear();
		};

		node *lnode = new node;
		while (st.size()!=0)
		{
			if (st.size()==1)
			{
				lnode->college = st.top();
			}
			else
			{
				lnode->department.push_front(st.top());
			}
			st.pop();
		}
		l.push_back(lnode);
		ls.pop_back();
	}
}
void CompoundJson()
{
	string str ;
	while (l.size())
	{
		node *no = l.front();
		str = str + "{" +'\n'+ "name:'" + no->college + "',";
		string temp=" DepartmentList: [";
		while (no->department.size())
		{
			if (no->department.size()==1)
			{
				temp = temp + "{name : '" + no->department.front() + "'}";
			}
			else
			{
				temp = temp + "{name : '" + no->department.front() + "'},";
			}
			no->department.pop_front();
		}
		temp = temp + "]";
		if (l.size()==1)
		{
			str = str + temp + '\n'+"}";
		}
		else
		{
			str = str + temp + '\n'+"},"+'\n';
		}
		l.pop_front();
	}

	Json = "CollegeList = [" + str + "];";
	cout << Json << endl;
}
void WriteFile()
{
	ofstream o("NewJson.js");
	o << Json;
	o.close();
}


void main()
{
	LoadContext();
	LoadList();
	CompoundJson();
	WriteFile();
	cin.get();
}

 

 

 

 

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值