nav.js
3.02 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
let $ = require('yoho-jquery');
let WILL_BEGIN = '即将开始';
let WILL_END = '即将结束';
let ONLINE_FORECAST = '上线预告';
// nav 滚动
// function initNavScroll(opt) {
// let $navBox,
// iScroll,
// _default = {
// el: '.outlet-nav'
// },
// options;
// options = $.extend({}, _default, opt);
// $navBox = $(options.el);
// function scroll(index) {
// let $ele;
// $ele = $navBox.find('li').eq(index);
// if ($ele.length > 0) {
// setTimeout(function() {
// iScroll.scrollToElement($ele[0], 400);
// }, 1);
// }
// }
// iScroll = new IScroll($navBox[0], {
// scrollX: true,
// scrollY: false,
// tap: true,
// eventPassthrough: true,
// preventDefault: true
// });
// return {
// goto: scroll
// };
// }
// 获取url中的参数
function getUrlParam(name, url) {
let reg = new RegExp('(^|&)' + name + '=([^&]*)(&|$)'); // 构造一个含有目标参数的正则表达式对象
let urlTest = url || window.location.href;
let r = urlTest.slice(urlTest.indexOf('?') + 1).match(reg); // 匹配目标参数
// 返回参数值
if (r !== null) {
return decodeURIComponent(r[2]);
} else {
return null;
}
}
// 获取创意生活和即将结束的index
function getOtherIndex() {
$('#index_nav').find('li').each(function() {
if ($(this).find('a').text() === ONLINE_FORECAST) {
$(this).attr({
'data-nav': 'other',
'data-type': 3
});
} else if ($(this).find('a').text() === WILL_END) {
$(this).attr({
'data-nav': 'other',
'data-type': 2
});
} else if ($(this).find('a').text() === WILL_BEGIN) {
$(this).attr({
'data-nav': 'other'
});
}
});
}
// 选中顶部导航
function activeNav() {
let $nav = $('#index_nav');
let index = getUrlParam('yh_channel');
// console.log(index)
// 判断是否有首页选项
let flag = false;
$nav.find('li').each(function() {
let $this = $(this);
let url = $this.find('a').attr('href');
let code = getUrlParam('content_code', url);
if (code === 'c19ffa03f053f4cac3690b22c8da26b7') {
flag = true;
return false;
}
});
getOtherIndex();
if (index === null) {
index = getUrlParam('type');
if (index === null) {
$nav.find('li:not([data-nav="other"])').eq(0).addClass('active').siblings().removeClass('active');
} else {
$nav.find('li[data-type=' + index + ']').addClass('active').siblings().removeClass('active');
}
} else {
if (!flag) {
index -= 1;
}
$nav.find('li:not([data-nav="other"])').eq(index).addClass('active').siblings().removeClass('active');
}
}
activeNav();
// module.exports = initNavScroll;