使用Element怎么实现日历布局

发布时间:2021-06-18 17:44:39 作者:Leah
来源:亿速云 阅读:322

今天就跟大家聊聊有关使用Element怎么实现日历布局,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。

1.基于Bootstrap的栅格布局

<div id="home" >
    <div class="col-md-6 col-md-offset-3">
        <el-calendar>
            <template slot="dateCell" slot-scope="{date, data}">
                <div  @click="dialogVisible = true">
                    <p :class="data.isSelected ? 'is-selected' : ''">
                        {{ data.day.split('-')[2] }}
                    </p>
                </div>
            </template>
        </el-calendar>
    </div>
    <el-dialog
            title="新增事件"
            :visible.sync="dialogVisible"
            width="60%"
            :before-close="handleClose">
        <div class="row">
            <div class="col-md-4">
                <form class="form-horizontal">
                    <div class="form-group clearfix ">
                        <label class="col-sm-4 control-label bk-lh40 pt0">工作日期</label>
                        <div class="col-sm-8">
                            <el-date-picker v-model="addDate" type="date" placeholder="选择日期" format="yyyy-MM-dd"
                                            value-format="yyyy-MM-dd">
                            </el-date-picker>
                        </div>
                    </div>
                </form>
                <form class="form-horizontal">
                    <div class="form-group clearfix ">
                        <label class="col-sm-4 control-label bk-lh40 pt0">工作类别</label>
                        <div class="col-sm-8">
                            <el-select v-model="addJobType" >
                                <el-option
                                        v-for="item in jobTypeData"
                                        :label="item.key"
                                        :value="item.key">
                                </el-option>
                            </el-select>
                        </div>
                    </div>
                </form>
                <form class="form-horizontal">
                    <div class="form-group clearfix ">
                        <label class="col-sm-4 control-label bk-lh40 pt0">客户名称</label>
                        <div class="col-sm-8">
                            <el-select v-model="searchCustomer" placeholder="请选择客户" >
                                <el-option
                                        v-for="item in customerData"
                                        :label="item.bk_username"
                                        :value="item.bk_username">
                                </el-option>
                            </el-select>
                        </div>
                    </div>
                </form>
            </div>
            <div class="col-md-4">
                <form class="form-horizontal">
                    <div class="form-group clearfix ">
                        <label class="col-sm-4 control-label bk-lh40 pt0">开始时间</label>
                        <div class="col-sm-8">
                            <el-time-select v-model="addStartTime"
                                            :picker-options="{start: '08:00',step: '00:30',end: '23:30'}"></el-time-select>
                        </div>
                    </div>
                </form>
                <form class="form-horizontal">
                    <div class="form-group clearfix ">
                        <label class="col-sm-4 control-label bk-lh40 pt0">事件状态</label>
                        <div class="col-sm-8">
                            <el-select v-model="addStatus" >
                                <el-option
                                        v-for="item in statusData"
                                        :label="item.key"
                                        :value="item.key">
                                </el-option>
                            </el-select>
                        </div>
                    </div>
                </form>
                <form class="form-horizontal">
                    <div class="form-group clearfix ">
                        <label class="col-sm-4 control-label bk-lh40 pt0">项目名称</label>
                        <div class="col-sm-8">
                            <el-select v-model="addProjectName" >
                                <el-option
                                        v-for="item in projectData"
                                        :label="item.key"
                                        :value="item.title">
                                </el-option>
                            </el-select>
                        </div>
                    </div>
                </form>
            </div>
            <div class="col-md-4">
                <form class="form-horizontal">
                    <div class="form-group clearfix ">
                        <label class="col-sm-4 control-label bk-lh40 pt0">结束时间</label>
                        <div class="col-sm-8">
                            <el-time-select v-model="addEndTime"
                                            :picker-options="{start: '08:00',step: '00:30',end: '23:30'}"></el-time-select>
                        </div>
                    </div>
                </form>
                <form class="form-horizontal">
                    <div class="form-group clearfix ">
                        <label class="control-label col-sm-4 bk-lh40 pt0">地点</label>
                        <div class="col-sm-8">
                            <el-select v-model="addAddress" >
                                <el-option
                                        v-for="item in addressData"
                                        :label="item.key"
                                        :value="item.key">
                                </el-option>
                            </el-select>
                        </div>
                    </div>
                </form>
                <form class="form-horizontal">
                    <div class="form-group clearfix ">
                        <label class="control-label col-sm-4 bk-lh40 pt0">事件性质</label>
                        <div class="col-sm-8">
                            <el-select v-model="addEventType" >
                                <el-option
                                        v-for="item in eventTypeData"
                                        :label="item.key"
                                        :value="item.key">
                                </el-option>
                            </el-select>
                        </div>
                    </div>
                </form>
            </div>
            <div class="col-md-8">
                <form class="form-horizontal">
                    <div class="form-group clearfix ">
                        <label class="col-sm-2 control-label bk-lh40 pt0">事件标题:</label>
                        <div class="col-sm-10">
                            <el-select v-model="addEventTitle" placeholder="请选择" >
                                <el-option v-for="item in eventTitleData" :label="item.key"
                                           :value="item.title"></el-option>
                            </el-select>
                        </div>
                    </div>
                </form>
            </div>
            <div class="col-md-8">
                <form class="form-horizontal">
                    <div class="form-group clearfix ">
                        <label class="col-sm-2 control-label bk-lh40 pt0">工作内容:</label>
                        <div class="col-sm-10">
                            <el-input v-model="addJobContent" type="textarea"
                                      :autosize="{ minRows: 2, maxRows: 4}"></el-input>
                        </div>
                    </div>
                </form>
            </div>
        </div>
      <span slot="footer" class="dialog-footer">
        <el-button @click="dialogVisible = false">取 消</el-button>
        <el-button type="primary" @click="dialogVisible = false">确 定</el-button>
      </span>
    </el-dialog>
</div>

<script type="text/javascript">
    new Vue({
        el: '#home',
        data: {
            dialogVisible: false,
            addDate: new Date(),
            addJobType: '项目工作',
            addStatus: '计划中',
            addProjectName: '',
            addAddress: '广州公司',
            addEventTitle: '',
            searchCustomer: '',
            addEventType: '计划任务',
            addJobContent: '',
            addStartTime: '09:00',
            addEndTime: '18:00',
            projectData: [],
            eventTitleData: [],
            jobTypeData: [
                {
                    "key": "项目工作"
                },
                {
                    "key": "售前工作"
                },
                {
                    "key": "讲师授课"
                },
                {
                    "key": "知识准备"
                },
                {
                    "key": "团队管理"
                },
                {
                    "key": "年假调休"
                },
                {
                    "key": "产品研发"
                },
                {
                    "key": "客户拜访"
                },
                {
                    "key": "其他工作"
                }
            ],
            eventTypeData: [
                {
                    "key": "计划任务"
                },
                {
                    "key": "项目事件"
                },
                {
                    "key": "其他工作"
                }
            ],
            addressData: [
                {
                    "key": "广州公司"
                },
                {
                    "key": "深圳公司"
                },
                {
                    "key": "北京公司"
                },
                {
                    "key": "上海公司"
                },
                {
                    "key": "客户处"
                },
                {
                    "key": "其他"
                }
            ],
            statusData: [
                {
                    "key": "计划中"
                },
                {
                    "key": "执行未完成"
                },
                {
                    "key": "已完成"
                }
            ],
            customerData: []
        },
        mounted() {
            this.init()
        },
        methods: {
            init() {

            },
            handleClose(done) {
                this.dialogVisible = false
            }
        }
    })
</script>
<style>
    .is-selected {
        color: red;
    }
    .el-dialog__header {
        background: #3498DB;
    }
    .el-dialog__title {
        color: white;
    }
    .el-icon-close:before {
        color: white;
    }
    .el-dialog__footer {
        text-align: center;
    }
</style>

2.基于Element的栅格布局

<div id="home" >
    <el-row>
        <el-col :span="10" :offset="7">
          <el-calendar>
            <template slot="dateCell" slot-scope="{date, data}">
                <div  @click="dialogVisible = true">
                    <p :class="data.isSelected ? 'is-selected' : ''">{{ data.day.split('-')[2] }}</p>
                </div>
            </template>
        </el-calendar>
      </el-col>
    </el-row>
    <el-dialog title="新增事件" :visible.sync="dialogVisible" width="60%" :before-close="handleClose">
        <el-row :gutter="40">
            <el-col :span="8">
                <el-form label-width="100px">
                    <el-form-item label="工作日期">
                        <el-date-picker v-model="addDate" type="date" format="yyyy-MM-dd" value-format="yyyy-MM-dd" >
                            </el-date-picker>
                    </el-form-item>
                    <el-form-item label="工作类别">
                        <el-select v-model="addJobType" >
                            <el-option v-for="item in jobTypeData" :label="item.key" :value="item.key"></el-option>
                        </el-select>
                    </el-form-item>
                    <el-form-item label="活动区域">
                        <el-select v-model="searchCustomer" placeholder="请选择客户" >
                            <el-option v-for="item in customerData" :label="item.bk_username" :value="item.bk_username"></el-option>
                        </el-select>
                    </el-form-item>
                </el-form>
            </el-col>
            <el-col :span="8">
                <el-form label-width="100px">
                    <el-form-item label="开始时间">
                        <el-time-select v-model="addStartTime" :picker-options="{start: '08:00',step: '00:30',end: '23:30'}" ></el-time-select>
                    </el-form-item>
                    <el-form-item label="事件状态">
                        <el-select v-model="addStatus" >
                            <el-option v-for="item in statusData" :label="item.key" :value="item.key"></el-option>
                        </el-select>
                    </el-form-item>
                    <el-form-item label="项目名称">
                        <el-select v-model="addProjectName" >
                            <el-option v-for="item in projectData" :label="item.key" :value="item.title"></el-option>
                        </el-select>
                    </el-form-item>
                </el-form>
            </el-col>
            <el-col :span="8">
                <el-form label-width="100px">
                    <el-form-item label="结束时间">
                        <el-time-select v-model="addEndTime" :picker-options="{start: '08:00',step: '00:30',end: '23:30'}" ></el-time-select>
                    </el-form-item>
                    <el-form-item label="地点">
                        <el-select v-model="addAddress" >
                            <el-option v-for="item in addressData" :label="item.key" :value="item.key"></el-option>
                        </el-select>
                    </el-form-item>
                    <el-form-item label="事件性质">
                        <el-select v-model="addEventType" >
                            <el-option v-for="item in eventTypeData" :label="item.key" :value="item.key"></el-option>
                        </el-select>
                    </el-form-item>
                </el-form>
            </el-col>
            <el-col :span="16">
                <el-form label-width="100px">
                    <el-form-item label="事件标题">
                        <el-select v-model="addEventTitle" placeholder="请选择" >
                            <el-option v-for="item in eventTitleData" :label="item.key" :value="item.title"></el-option>
                        </el-select>
                    </el-form-item>
                </el-form>
            </el-col>
            <el-col :span="16">
                <el-form label-width="100px">
                    <el-form-item label="工作内容">
                        <el-input v-model="addJobContent" type="textarea" :autosize="{ minRows: 2, maxRows: 4}"></el-input>
                    </el-form-item>
                </el-form>
            </el-col>
        </el-row>
      <span slot="footer" class="dialog-footer">
        <el-button @click="dialogVisible = false">取 消</el-button>
        <el-button type="primary" @click="dialogVisible = false">确 定</el-button>
      </span>
    </el-dialog>
</div>

<script type="text/javascript">
    new Vue({
        el: '#home',
        data: {
            dialogVisible: false,
            addDate: new Date(),
            addJobType: '项目工作',
            addStatus: '计划中',
            addProjectName: '',
            addAddress: '广州公司',
            addEventTitle: '',
            searchCustomer: '',
            addEventType: '计划任务',
            addJobContent: '',
            addStartTime: '09:00',
            addEndTime: '18:00',
            projectData: [],
            eventTitleData: [],
            jobTypeData: [
                {
                    "key": "项目工作"
                },
                {
                    "key": "售前工作"
                },
                {
                    "key": "讲师授课"
                },
                {
                    "key": "知识准备"
                },
                {
                    "key": "团队管理"
                },
                {
                    "key": "年假调休"
                },
                {
                    "key": "产品研发"
                },
                {
                    "key": "客户拜访"
                },
                {
                    "key": "其他工作"
                }
            ],
            eventTypeData: [
                {
                    "key": "计划任务"
                },
                {
                    "key": "项目事件"
                },
                {
                    "key": "其他工作"
                }
            ],
            addressData: [
                {
                    "key": "广州公司"
                },
                {
                    "key": "深圳公司"
                },
                {
                    "key": "北京公司"
                },
                {
                    "key": "上海公司"
                },
                {
                    "key": "客户处"
                },
                {
                    "key": "其他"
                }
            ],
            statusData: [
                {
                    "key": "计划中"
                },
                {
                    "key": "执行未完成"
                },
                {
                    "key": "已完成"
                }
            ],
            customerData: []
        },
        mounted() {
            this.init()
        },
        methods: {
            init() {

            },
            handleClose(done) {
                this.dialogVisible = false
            }
        }
    })
</script>
<style>
    .is-selected {
        color: red;
    }
    .el-dialog__header {
        background: #3498DB;
    }
    .el-dialog__title {
        color: white;
    }
    .el-icon-close:before {
        color: white;
    }
    .el-dialog__footer {
        text-align: center;
    }
</style>

看完上述内容,你们对使用Element怎么实现日历布局有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注亿速云行业资讯频道,感谢大家的支持。

推荐阅读:
  1. element-ui响应式布局
  2. 怎么使用原生js实现日历效果

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

element

上一篇:log4j2中怎么配置单独文件日志打印

下一篇:python清洗文件中数据的方法

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》