document.addEventListener('DOMContentLoaded', () => { /* 激活轮播图功能 */ { if ($('.joe_index__banner .swiper-container').length !== 0) { let direction = 'horizontal'; if (!Joe.IS_MOBILE && $('.joe_index__banner-recommend .item').length === 2) direction = 'vertical'; new Swiper('.swiper-container', { keyboard: false, direction, loop: true, autoplay: true, mousewheel: true, pagination: { el: '.swiper-pagination' }, navigation: { nextEl: '.swiper-button-next', prevEl: '.swiper-button-prev' } }); } } /* 初始化首页列表功能 */ { const getListMode = _ => { if (_.mode === 'default') { return `
  • ${_.title}
    置顶${_.title} ${_.abstract}
    • ${_.created}
    • ${_.views} 阅读
    • ${_.commentsNum} 评论
    • ${_.agree} 点赞
  • `; } else if (_.mode === 'single') { return `
  • 置顶${_.title}
    • ${_.created}
    • ${_.views} 阅读
    • ${_.commentsNum} 评论
    • ${_.agree} 点赞
    ${_.title}
    ${_.abstract}
  • `; } else if (_.mode === 'multiple') { return `
  • 置顶${_.title} ${_.abstract}
    ${_.image .map((item, index) => { if (index < 3) { return `${_.title}`; } }) .join('')}
  • `; } else { return `
  • 置顶${_.title} ${_.abstract}
    • ${_.created}
    • ${_.views} 阅读
    • ${_.commentsNum} 评论
    • ${_.agree} 点赞
  • `; } }; let queryData = { page: 1, pageSize: 12, type: 'created' }; const initDom = () => { $('.joe_index__list .joe_list').html(''); $('.joe_load').show(); let activeItem = $('.joe_index__title-title .item[data-type="' + queryData.type + '"]'); let activeLine = $('.joe_index__title-title .line'); activeItem.addClass('active').siblings().removeClass('active'); activeLine.css({ left: activeItem.position().left, width: activeItem.width() }); }; const pushDom = () => { return new Promise((reslove, reject) => { $('.joe_load').attr('loading', true); $('.joe_load').html('loading...'); $('.joe_index__list .joe_list__loading').show(); $.ajax({ url: Joe.BASE_API, type: 'POST', data: { routeType: 'publish_list', page: queryData.page, pageSize: queryData.pageSize, type: queryData.type }, success(res) { if (res.data.length === 0) { $('.joe_load').removeAttr('loading'); $('.joe_load').html('查看更多'); $('.joe_load').hide(); $('.joe_index__list .joe_list__loading').hide(); return Qmsg.warning('没有更多内容了'); } res.data.forEach(_ => $('.joe_index__list .joe_list').append(getListMode(_))); $('.joe_load').removeAttr('loading'); $('.joe_load').html('查看更多'); $('.joe_index__list .joe_list__loading').hide(); reslove(res.data.length > 0 ? res.data.length - 1 : 0); } }); }); }; initDom(); pushDom(); $('.joe_index__title-title .item').on('click', async function () { if ($(this).attr('data-type') === queryData.type) return; queryData = { page: 1, pageSize: 12, type: $(this).attr('data-type') }; initDom(); pushDom(); }); $('.joe_load').on('click', async function () { if ($(this).attr('loading')) return; queryData.page++; let length = await pushDom(); length = $('.joe_index__list .joe_list .joe_list__item').length - length; const queryElement = `.joe_index__list .joe_list .joe_list__item:nth-child(${length})`; const offset = $(queryElement).offset().top - $('.joe_header').height(); window.scrollTo({ top: offset - 15, behavior: 'smooth' }); }); } /* 激活列表特效 */ { const wow = $('.joe_index__list').attr('data-wow'); if (wow !== 'off' && wow) new WOW({ boxClass: 'wow', animateClass: `animated ${wow}`, offset: 0, mobile: true, live: true, scrollContainer: null }).init(); } });