[HTML+Bootstrap+CSS+Vue.js] 利用v-for循环、modal模态框、datetime控件添加起止时间记录,要求简单验证输入的时间格式

12 篇文章 0 订阅
10 篇文章 0 订阅
  • 需求: 点击按钮弹出模态框,用户利用date+time控件输入时间;点击提交时,若输入格式完整,则添加一条记录到页面并关闭模态框;若输入格式有误,则模态框不关闭,且显示警告文字;当用户重新输入时警告文字消失
  • 美化: 从左到右排列记录,间距适当,队列末尾放置+号按钮,并添加浅色虚线背景框,弹出的模态框居中显示,尺寸适宜
  • 技术: HTML + Bootstrap + CSS + Vue.js

HTML代码:

<div class="container-fluid" id="example">
    <!-- Bootstrap网格系统布局,使一行排列4项 -->
    <div class="row">
        <!-- Vue.js v-for循环实现数据叠加 -->
        <div class="col-3" v-for="(item, index) in items" :key="index">
            <div class="jumbotron p-3 board">
                <h6 class="text-center">第 {{ index+1 }} 次计时</h6>
                <br>
                <p>开始时间:{{ item.startTime }}</p>
                <p>结束时间:{{ item.endTime }}</p>
            </div>
        </div>
        <div class="col-3">
            <div class="addBtn">
                <!-- Bootstrap modal组件,弹出模态框 -->
                <a href="#addModal" data-toggle="modal" data-backdrop="static"><i class="fas fa-plus-circle"></i></a>
            </div>
        </div>
    </div>
    <!-- 模态框内容 -->
    <div class="modal" id="addModal" tabindex="-1">
        <div class="modal-dialog modal-dialog-centered">
            <div class="modal-content modalContent">
                <div class="modal-header">
                    <h6 class="modal-title">添加记录</h6>
                    <button class="close" data-dismiss="modal"><span>&times;</span></button>
                </div>
                <div class="modal-body">
                    <!-- input group组件 -->
                    <div class="input-group my-3">
                        <div class="input-group-prepend">
                            <span class="input-group-text">开始时间:</span>
                        </div>
                        <!-- Vue.js v-model双向绑定表单数据,v-on绑定focus事件 -->
                        <input type="datetime-local" class="form-control" placeholder="YYYY-MM-DD hh:mm" v-model="stVal" @focus.stop="onFocus">
                    </div>
                    <div class="input-group my-3">
                        <div class="input-group-prepend">
                            <span class="input-group-text">结束时间:</span>
                        </div>
                        <input type="datetime-local" class="form-control" placeholder="YYYY-MM-DD hh:mm" v-model="etVal" @focus.stop="onFocus">
                    </div>
                </div>
                <div class="modal-footer">
                    <!-- 格式有误时的警告文字,v-show切换是否可见 -->
                    <span class="text-danger" v-show="isShow">时间格式有误,请重新输入!</span>&nbsp;
                    <!-- 提交按钮绑定click事件 -->
                    <button class="btn btn-primary" @click.stop="onSubmit">提交</button>
                    <button class="btn btn-secodary" data-dismiss="modal">取消</button>
                </div>
            </div>
        </div>
    </div>
</div>

CSS代码:

#example {
    width: 100vw;
    height: 100vh;
    line-height: 1;
    padding: 3rem;
}
.board, .addBtn {
    width: 260px;
    height: 130px;
}
.addBtn {
    border: 3px dotted #e9ecef;    /* 画虚线框 */
    background-color: rgba(233, 236, 239, .3);
    text-align: center;
    line-height: 130px;    /* 使图标居中 */
}
.addBtn i {
    color: #e9ecef;
    font-size: 3rem;    /* 调整图标尺寸 */
}
.modalContent {
    width: 400px;
}

JS代码:

//由于本案未在vue中引入jquery,所以要将关闭模态框的modal()方法重新定义一个js方法
var mh = {
    modalHide: function(){
        $('#addModal').modal('hide');
    }
};
var vm = new Vue({
    el: '#example',
    data: {
        items: [
        {
            startTime: '2018-11-09 16:53',
            endTime: '2018-11-11 18:34'
        },
        {
            startTime: '2018-11-12 15:52',
            endTime: '2018-12-12 14:25'
        },
        ],
        stVal: '',    //使输入框初始值为空
        etVal: '',
        isShow: false    //默认警告文字不可见
    },
    methods: {
        //验证格式的方法
        testPattern: function(t){
            var reg = /[0-9]{4}-[0-9]{2}-[0-9]{2}\s+[0-9]{2}:[0-9]{2}/;    //简单位数验证:YYYY-MM-DD hh:mm
            return reg.test(t);    //参数匹配正则表达式,返回true
        },
        //“提交”按钮点击事件
        onSubmit: function(){
            var st = this.stVal.replace(/T/, ' ');    //将从输入框获取的值中的T替换为空格
            var et = this.etVal.replace(/T/, ' ');
            if(this.testPattern(st) && this.testPattern(et)){    //仅当输入的起止时间都符合格式要求时
                this.items.push(
                {
                    startTime: st,
                    endTime: et    //将数据添加到数组,并在页面显示新增的记录
                },
                );
                mh.modalHide();    //同时关闭模态框
            }
            else{
                this.isShow = true;    //若格式有误则显示警告文字
            };
        },
        //输入框获取焦点事件
        onFocus: function(){
            this.isShow = false;    //切换警告文字为不可见
        }
    }
})

效果示例:

在这里插入图片描述
在这里插入图片描述

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要实现多个弹出框,可以通过动态创建多个模态框的方式来实现。以下是一种实现方法: 1. 在 HTML添加一个按钮,用于触发弹出框: ```html <button id="btnOpenModal" class="btn btn-primary">打开模态框</button> ``` 2. 在 JavaScript 中编写代码,用于动态创建模态框: ```javascript // 模态框计数器,用于生成唯一的 ID var modalCount = 0; // 创建模态框函数 function createModal() { // 创建模态框 HTML var modalHTML = '<div id="modal' + modalCount + '" class="modal fade" tabindex="-1" role="dialog">'; modalHTML += '<div class="modal-dialog" role="document">'; modalHTML += '<div class="modal-content">'; modalHTML += '<div class="modal-header">'; modalHTML += '<h5 class="modal-title">模态框标题</h5>'; modalHTML += '<button type="button" class="close" data-dismiss="modal" aria-label="Close">'; modalHTML += '<span aria-hidden="true">×</span>'; modalHTML += '</button>'; modalHTML += '</div>'; modalHTML += '<div class="modal-body">'; modalHTML += '<p>模态框内容</p>'; modalHTML += '</div>'; modalHTML += '<div class="modal-footer">'; modalHTML += '<button type="button" class="btn btn-secondary" data-dismiss="modal">关闭</button>'; modalHTML += '<button type="button" class="btn btn-primary">保存</button>'; modalHTML += '</div>'; modalHTML += '</div>'; modalHTML += '</div>'; modalHTML += '</div>'; // 将模态框 HTML 添加到页面中 $('body').append(modalHTML); // 增加计数器,确保每个模态框具有唯一的 ID modalCount++; // 返回最新创建的模态框的 ID return 'modal' + (modalCount - 1); } ``` 3. 在 JavaScript 中编写代码,用于打开模态框: ```javascript // 点击按钮时打开模态框 $('#btnOpenModal').click(function () { // 创建一个新的模态框 var modalId = createModal(); // 打开新的模态框 $('#' + modalId).modal('show'); }); ``` 这样就可以通过点击按钮来打开多个模态框了。每次点击按钮时,都会动态创建一个新的模态框,并打开它。注意,这里使用了 jQuery 和 Bootstrap 的 JavaScript 插件。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值