摘要:而由于没有后端的数据支持,所有的数据都在表格中展示,所以需要将表格中的数据转为数据,再通过读取,然后用模板引擎渲染到页面上。
如图所示,是一个动态的表格,内容数量不定第一层分类是专业大类的分类,第二层分类的国家的分类,第三层分类是具体专业名的分类(就是不同的色块栏),甚至还有具体的院校名分类。而由于没有后端的数据支持,所有的数据都在excel表格中展示,所以需要将表格中的数据转为json数据,再通过ajax读取,然后用模板引擎渲染到页面上。
这里需要注意的是json的数据内容一定要和模板的内容互相匹配,这里需要引用的有jQuery,Boostrap,art-Template,将css和js引入后,话不多说,先从HTML开始:
艺考生留学指南
陕西新东方前途出国
电话:029-87203365
地址:西安市高新区林凯国际10层(科技路与高新二路
十字东南角)
Copyright © 2017-2018 陕西新东方前途出国
如上所示,为全部HTML,其中id为template的就是模板引擎的模板啦,将整个表格部分都看做为模板引擎之内的内容,变量部分就是需要在json中写上的内容,关于art-template的语法,可以看art_template模板引擎渲染数据的小方法。
css 部分不多说。
JS内容如下:
window.onload = function () {
var data;
$.ajax({
dataType: "json",
url: "data.json",
data: data,
type: "get",
success: function (data, key) {
var datas = data;
console.log(data);
for (var key in datas) {};
// 专业分类点击事件
$(".majors>ul>li").hover(
function (e) {
$(this).children(".mask").css("background", "rgba(0, 0, 0, .3)");
$(this).siblings().children(".mask").css("background", "rgba(0, 0, 0, .5)");
},
function (e) {
$(this).children(".mask").css("background", "rgba(0, 0, 0, .5)");
$(this).siblings().children(".mask").css("background", "rgba(0, 0, 0, .5)");
}
);
$("body").on("click", ".majors>ul>li", function (e) {
console.log("好好学习");
console.log($(this).index());
// 给当前项的兄弟元素加上阴影,给当前项去除阴影。
$(this).addClass("active");
$(this).siblings().removeClass("active");
$(this).find(".mask").css("background", "rgba(0, 0, 0, 0)");
$(this).siblings().find(".mask").css("background", "rgba(0, 0, 0, .5)");
//获取当前tab中鼠标停在的table栏的索引
var majorIndex = $(this).index();
// 取出所有数据中当前专业类目数据
var majorData = data[majorIndex];
console.log(majorData);
// 由于取出的是对象,所以遍历key,求出它的value,并赋值给新变量
for (var key in majorData) {
console.log(majorData[key]);
var majorDataA = majorData[key]
}
// 当国家项被点击时
$("body").on("click", ".countries>li", function () {
console.log($(this));
$(this).siblings().removeClass("selected");
$(this).addClass("selected")
$(".articles").html("");
console.log("天天向上");
// var countryIndex=$(this).index();
// console.log(countryIndex);
// var countryData=majorData
// 由于json数据结构的原因,此处不能用数组的index绑定,所以用id绑定。
var countryId = $(this).attr("id");
console.log(countryId)
// 得到每个国家的数据
var countryData = majorDataA[countryId];
console.log(countryData);
// 遍历当前国家项的数据
$.each(countryData, function (index, item) {
console.log(countryData[index]);
console.log(countryData[index].professional);
// 为国家项数据设置一个新变量
var countryDataIndex = countryData[index];
console.log(countryDataIndex.professional);
// 将国家项数据转为对象
var OBJ = {
items: countryDataIndex
};
console.log(OBJ);
// 将对象写入模板引擎并赋值给result变量
var result = template("template", OBJ);
console.log(countryDataIndex.university);
$(".articles").append(result);
})
// 设置左侧色块的的高度和右侧表格的高度相等。
var tHeight = $("table").height();
console.log(tHeight);
var aHeight = $("aside").height();
console.log(aHeight);
var aHeight = tHeight;
console.log(tHeight);
$("aside").css("height", aHeight);
})
$("#Americia").trigger("click");
})
$(".art").trigger("click");
}
})
注释上介绍的基本挺清楚啦,所以应该没什么需要解释的,如果需要请留言。
JSON的数据,这需要自己来梳理,略复杂,我梳理后效果是这样:
[{
"Performance": {
"Americia": [{
"professional": "暂无",
"direction": " ",
"university": [
"暂无"
],
"standards": [
"暂无"
],
"project": [
"点击了解"
]
}],
"England": [{
"professional": "戏剧",
"direction": " Drama",
"university": [
"伦敦大学皇家霍洛威学院",
"埃克塞特大学",
"华威大学",
"布里斯托大学"
],
"standards": [
"雅思5.0,写作5.0;
高中三年平均成绩75分以上",
"雅思5.5,单项不低于5.0,
高中三年平均成绩75分以上",
"雅思5.5,单项不低于5.5;
高中三年平均成绩85分以上",
"雅思6.0,写作5.5,其他不低于5.0;
高中三年平均成绩80分以上"
],
"project": [
"点击了解"
]
}],
"Canada": [{
"professional": "暂无",
"direction": " ",
"university": [
"暂无"
],
"standards": [
"暂无"
],
"project": [
"点击了解"
]
}],
"Austrilia": [{
"professional": "暂无",
"direction": " ",
"university": [
"暂无"
],
"standards": [
"暂无"
],
"project": [
"点击了解"
]
}],
"Europe": [{
"professional": "艺术
音乐与表演",
"direction": " Art music
performance",
"university": [
"意大利博洛尼亚大学,罗马三大"
],
"standards": [
"1. 高考文化课300分以上,高中毕业;
2. 意大利语A2水平,计划生"
],
"project": [
"点击了解"
]
}],
"Asia": [{
"professional": "戏剧
电影",
"direction": "Dramas
Movies",
"university": [
"韩国:韩国庆熙大学,韩国中央大学,韩国建国大学等"
],
"standards": [
"1.国内高三在读(完成高二学业水平测试)或高中毕业(或同等学历:中专,职高,技校),具有高中毕业证,高中艺术特长;
2.韩语TOPIK三级(可在韩国语学堂完成韩语学习);
3.表演艺术学部 : 一定量的对词及指定表演。 "
],
"project": [
"艺形者培训项目,境外升学辅导课程-点击了解"
]
}]
}
}
]
当然这只是数组中的一条数据,其他的还有很多条,但是结构都一样,这里一定要多用数组类型的json,因为需要对数据进行遍历,用对象就比较麻烦,所以我将很多数据内容都写成了数组,只有最底层的具体内容才写作对象,然后在模板引擎中调用起来很方便。另外提示一下,模板引擎自带遍历功能:模板引擎如何遍历json中的数据 ,所以对象中的具体内容直接让模板引擎遍历就好了,不用自己造轮子。
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/115656.html
摘要:概述数据字典主要解决下拉框数据填充和数据表格转义处理,一个数据字典可以多处使用。通过服务端异步请求加载数据列表。 概述 数据字典主要解决下拉框数据填充和数据表格转义处理,一个数据字典可以多处使用。 1.多个页面下拉框使用同样的数据,改一个地方需要把所有页面都要修改 2.数据表格转义代替自己手动写templet解析模板数据字典提供一个通用的处理方式,支持配置静态数据字典和动态数据...
摘要:概述数据字典主要解决下拉框数据填充和数据表格转义处理,一个数据字典可以多处使用。通过服务端异步请求加载数据列表。 概述 数据字典主要解决下拉框数据填充和数据表格转义处理,一个数据字典可以多处使用。 1.多个页面下拉框使用同样的数据,改一个地方需要把所有页面都要修改 2.数据表格转义代替自己手动写templet解析模板数据字典提供一个通用的处理方式,支持配置静态数据字典和动态数据...
摘要:而由于没有后端的数据支持,所有的数据都在表格中展示,所以需要将表格中的数据转为数据,再通过读取,然后用模板引擎渲染到页面上。 showImg(https://segmentfault.com/img/bV3N8M?w=1574&h=692);如图所示,是一个动态的表格,内容数量不定第一层分类是专业大类的分类,第二层分类的国家的分类,第三层分类是具体专业名的分类(就是不同的色块栏),甚至...
阅读 3950·2023-04-26 00:56
阅读 2953·2021-09-30 10:01
阅读 1220·2021-09-22 15:30
阅读 4255·2021-09-07 10:21
阅读 1852·2021-09-02 15:40
阅读 3098·2021-08-30 09:47
阅读 1607·2021-08-16 10:57
阅读 2069·2019-08-30 14:01