当前位置:首页 > 影视资讯 > 批量设置视频更新

批量设置视频更新

2个月前 (12-16)影视资讯173

在后台视频数据管理页面增加一个更新时间按钮,可以批量设置视频的更新时间,某些情况下还是挺好用的,一共涉及两处修改:

1、application/admin/controller/Vod.php

查找 public function field() 在这个函数上方新增

    public function updateTimeBatch()
    {
        $param = input();
        $ids = isset($param['ids']) ? $param['ids'] : '';
        $time = isset($param['time']) ? trim($param['time']) : '';

        if (empty($ids)) {
            return $this->error(lang('param_err'));
        }

        $timestamp = time();
        if (!empty($time)) {
            $tmp = strtotime($time);
            if ($tmp !== false) {
                $timestamp = $tmp;
            }
        }

        $where['vod_id'] = ['in', $ids];
        $update = ['vod_time' => $timestamp];
        $res = model('Vod')->fieldData($where, $update);
        if ($res['code'] > 1) {
            return $this->error($res['msg']);
        }
        return $this->success($res['msg']);
    }

2、application/admin/view/vod/index.html

查找

<a class="layui-btn layui-btn-primary j-iframe" data-checkbox="true" data-href="{:url('make/make?ac=info&tab=vod')}" href="javascript:;" title="{:lang('make_page')}"><i class="layui-icon">&#xe620;</i>{:lang('make_page')}</a>

在这段代码下方新增:

<a class="layui-btn layui-btn-primary" id="btnBatchUpdateTime" href="javascript:;" title="{:lang('update_time')}"><i class="layui-icon">&#xe637;</i>{:lang('update_time')}</a>


找到页面底部的js脚本里的
layui.use(['laypage', 'layer','form'], function() {
改为
layui.use(['laypage', 'layer','form','laydate'], function() {


找到
form = layui.form;
改为
form = layui.form,
laydate = layui.laydate;


找到
// 小屏幕下名称问题
if ($('body').width() <= 600) {
$('#table_th_vod_name').attr('width', '300');
}
在下方新增

$('#btnBatchUpdateTime').on('click', function () {
            var ids = [];
            $('.checkbox-ids:checked').each(function (index, item) {
                if (item.checked) {
                    ids.push(item.value);
                }
            });
            if (ids.length < 1) {
                layer.msg('{:lang('请先选择视频')}');
                return false;
            }

            var content = '<div style="padding:15px 20px 0 20px;">' +
                '<input type="text" class="layui-input" id="batchUpdateTimeInput" placeholder="{:lang('update_time')}">' +
                '<p style="margin-top:8px;color:#999;">{:lang('批量设置视频')} {:lang('update_time')}</p>' +
                '</div>';

            var openIndex = layer.open({
                type: 1,
                title: '{:lang('update_time')}',
                area: ['360px', '200px'],
                content: content,
                btn: ['{:lang('确定')}','{:lang('取消')}'],
                success: function () {
                    laydate.render({
                        elem: '#batchUpdateTimeInput',
                        type: 'datetime',
                        value: new Date()
                    });
                },
                yes: function () {
                    var timeVal = $('#batchUpdateTimeInput').val();
                    layer.msg('{:lang('wait_submit')}', {time: 500000});
                    $.post("{:url('updateTimeBatch')}", {ids: ids.join(','), time: timeVal}, function (res) {
                        layer.msg(res.msg, {}, function () {
                            if (res.code == 1) {
                                location.reload();
                            }
                        });
                    });
                    layer.close(openIndex);
                }
            });
        });

完整的js脚本代码为:

<script type="text/javascript">
    var curUrl="{:url('vod/data',$param)}";
    layui.use(['laypage', 'layer','form','laydate'], function() {
        var laypage = layui.laypage
                , layer = layui.layer,
                form = layui.form,
                laydate = layui.laydate;
                $ = layui.jquery;

        laypage.render({
            elem: 'pages'
            ,count: {$total}
            ,limit: {$limit}
            ,curr: {$page}
            ,layout: ['count', 'prev', 'page', 'next', 'limit', 'skip']
            ,jump: function(obj,first){
                if(!first){
                    location.href = curUrl.replace('%7Bpage%7D',obj.curr).replace('%7Blimit%7D',obj.limit);
                }
            }
        });

        // 小屏幕下名称问题
        if ($('body').width() <= 600) {
            $('#table_th_vod_name').attr('width', '300');
        }

        $('#btnBatchUpdateTime').on('click', function () {
            var ids = [];
            $('.checkbox-ids:checked').each(function (index, item) {
                if (item.checked) {
                    ids.push(item.value);
                }
            });
            if (ids.length < 1) {
                layer.msg('{:lang('请先选择视频')}');
                return false;
            }

            var content = '<div style="padding:15px 20px 0 20px;">' +
                '<input type="text" class="layui-input" id="batchUpdateTimeInput" placeholder="{:lang('update_time')}">' +
                '<p style="margin-top:8px;color:#999;">{:lang('批量设置视频')} {:lang('update_time')}</p>' +
                '</div>';

            var openIndex = layer.open({
                type: 1,
                title: '{:lang('update_time')}',
                area: ['360px', '200px'],
                content: content,
                btn: ['{:lang('确定')}','{:lang('取消')}'],
                success: function () {
                    laydate.render({
                        elem: '#batchUpdateTimeInput',
                        type: 'datetime',
                        value: new Date()
                    });
                },
                yes: function () {
                    var timeVal = $('#batchUpdateTimeInput').val();
                    layer.msg('{:lang('wait_submit')}', {time: 500000});
                    $.post("{:url('updateTimeBatch')}", {ids: ids.join(','), time: timeVal}, function (res) {
                        layer.msg(res.msg, {}, function () {
                            if (res.code == 1) {
                                location.reload();
                            }
                        });
                    });
                    layer.close(openIndex);
                }
            });
        });

    });
</script>


扫描二维码推送至手机访问。

版权声明:本文由沁馨影视网发布,如需转载请注明出处。

本文链接:https://qinxin.qxnnn.com/yszx/542.html

分享给朋友:

相关文章

《活着》跨越年代的叙事和深刻的人性刻画!

《活着》跨越年代的叙事和深刻的人性刻画!

一、主题解析:历史褶皱中的个体命运影片通过福贵(葛优饰)从地主少爷到贫苦农民的一生,将中国现代史的重大事件(土地改革、大跃进、文革)浓缩为个人命运的沉浮。皮影戏作为贯穿全片的隐喻符号,既象征着传统文化在时代变革中的顽强存续,也暗示人物如提线木偶般被历史浪潮裹挟的无奈。导演采用黑色幽默手法呈现苦难,如...

《寄生虫》的阶级隐喻

《寄生虫》的阶级隐喻

一、引言:一座房子的两种人生奉俊昊用半地下室的霉味与豪宅的香氛,在2019年撕开了全球中产社会的华丽帷幕。《寄生虫》通过金基泽一家与朴社长一家的命运交织,将韩国社会的阶级固化转化为具象的空间对抗。影片中垂直分布的住宅空间,既是物理层面的建筑分层,更是社会阶层的残酷映射。二、空间叙事中的阶级符号学半地...

《盗梦空间》如同一座精心设计的俄罗斯套娃

《盗梦空间》如同一座精心设计的俄罗斯套娃

《盗梦空间》的叙事结构如同一座精心设计的俄罗斯套娃,每一层梦境都既是容器又是被容者。克里斯托弗·诺兰通过四层嵌套的梦境空间(现实→第一层梦境→第二层梦境→迷失域),构建了罕见的套层叙事范式。这种结构并非简单的炫技,而是与影片核心命题形成镜像:当主角柯布在现实与梦境间穿梭时,观众同样陷入对叙事真实性的...

同甘共苦 Together (2025)

同甘共苦 Together (2025)

裂痕中的共生:《同甘共苦》的当代寓言当全球气候危机与地缘冲突在2025年达到临界点,韩国导演朴赞郁的《同甘共苦》以一场横跨朝鲜半岛的生态灾难为切口,用极具张力的影像语言撕开了现代文明虚伪的共生假面。这部获得戛纳评审团特别奖的作品,通过三个家庭在核泄漏阴影下的命运交织,构建了一幅关于人性、权力与生存的...

《招魂 4:终章》:以爱为咒,为十年黑暗谢幕

《招魂 4:终章》:以爱为咒,为十年黑暗谢幕

当 1986 年宾夕法尼亚郊区的月光透过教堂彩窗,在沃伦夫妇布满岁月痕迹的脸上投下斑驳光影时,《招魂 4:终章》用一声熟悉的地板吱呀声,为长达十二年的 “招魂宇宙” 拉开了告别序曲。这部由温子仁监制、迈克尔・查维斯执导的收官之作,没有沉溺于血浆与尖叫的感官刺激,而是将驱魔故事根植于家庭温情的土壤,让...

《恶意(2025)》:流量围猎下的人性困局与真相微光

《恶意(2025)》:流量围猎下的人性困局与真相微光

当滨江三院的玻璃窗映出双人坠楼的惊悚剪影,当社交媒体的评论区以每秒十条的速度刷新着恶毒揣测,《恶意(2025)》用一场精心设计的悬疑迷局,将镜头对准了数字时代最隐秘的社会病灶。这部由陈思诚监制,来牧宽、姚文逸联合执导,张小斐领衔主演的现实题材作品,没有沉溺于悬疑片的猎奇快感,而是以五重反转的叙事张力...