會議室預定功能


  一、功能介紹

這是一個基於前端頁面js代碼的動態效果和后端對數據庫數據更新的操作,主要實現的是會議室的預定功能,當員工進入預定頁面后可以看到某天的某個會議室的某個時段是否被預定,當沒被預定的情況下,就可以預定會議室,這相當於對於會議室這種共享資產的合理化分配,快速便捷的完成會議室的預定。前端頁面時長這樣的。

  從上圖中,可以清晰的看出那些人預定那些房間。我們要實現的功能如下:

1,當選擇一個時間,然后點擊提交按鈕,就會發送一個基於form表單的post請求,會把時間發過去然后,返回的頁面就是剛才選擇日期的會議室預定情況

2,點擊空白小格子時,顏色會變淺綠,

3,點擊被預定的小格子時,當名字是自己的名字時,會使顏色消失,變成白色小格子,然后把房間號和時間段放入刪除列表;當點擊的名字不是自己時,會彈出警告框,不能對其進行操作

4,點擊保存按鈕時,會把所有的淺綠的小格子的房間號和時間段放入添加列表;然后發送ajax請求,把添加列表和刪除列表發送到后端處理

5,后端拿到數據,先對刪除列表,把要刪除的刪除;然后再處理添加列表,把該添加的添加上

  二、代碼

  1,創建模型

class UserInfo(models.Model): #這是user表
  pass


class
House(models.Model): #這是房間表 '''會議室表''' name=models.CharField(max_length=5) size=models.CharField(max_length=5) def __str__(self): return self.name times=((1, '09:00-10:00'), (2, '10:00-11:00'), (3, '11:00-12:00'), (4, '12:00-13:00'), (5, '13:00-14:00'), (6, '14:00-15:00'), (7, '15:00-16:00'), (8, '16:00-17:00'), (9, '17:00-18:00'), (10, '18:00-19:00'), (11, '19:00-20:00'),(12, '20:00-21:00')) class Order(models.Model): #這是會議室預定記錄表 '''會議室預定記錄表''' date=models.DateField() user=models.ForeignKey(to='UserInfo',on_delete=models.CASCADE) house=models.ForeignKey(to='House',on_delete=models.CASCADE) time = models.IntegerField(choices=times) class Meta: unique_together = ("date", "house", 'time') #這是聯合唯一,

  2,前端代碼

{% extends 'base.html' %}
{% block css %}
    <style>
        .outer{
            width: 100%;
            height: 40px;
            background-color: #337ab7;
            color: white;
            line-height: 40px;
        }

        .left{
            float: left;
            margin-top: 10px;
            margin-left: 10px;
            color: black;
            height: 20px;
        }
        #title{
            float: right;
            margin-right: 500px;
            font-size: 20px;
        }
        #date{
            float: left;
        }
    </style>
{% endblock %}
{% block content %}
    <div class="container">
        <div class="outer">
            <div id="date">          #這是日期
                <form action="/houseorder/" method="post">
                {% csrf_token %}
                <div>                        
                    <input type="submit" style="color: black;height: 20px;margin-top: 10px;line-height: 20px">
                    <input type="date" name="time" class="left" value="{{ date }}">
                </div>
                </form>
            </div>
            <div id="title">會議室預定表</div>
        </div>
        <table class="table table-bordered">
            <thead>
                <tr>
                    <th>會議室</th>
                    {% for choice in choices %}   #這是循環生產時間的信息,也就是表頭
                        <th>{{ choice.1 }}</th>
                    {% endfor %}
                </tr>
            </thead>
            <tbody>
                {{ data }}         #所有的表體數據都是由后端構造的
            </tbody>
        </table>
        <button class="btn btn-info tijiao">保存</button>
    </div>

{% endblock %}
{% block script %}
    <script>
        var add_dic={};
        var del_dic={};
        //給每個nn類的標簽綁定點擊事件
        $('.nn').click(function () {
            var text=$(this).text();
            var user=$('.user').attr('id');
            console.log(user);
            var num=$(this).children('span').first().attr('class');
            var name=$(this).parent().attr('class');
            //已經被別人選中的
            if ($(this).hasClass('warning')){
                alert('別人已經選定')
            }
            //被自己選中的
            else if ($(this).hasClass('danger')){
                $(this).removeClass('danger');
                $(this).children('span').text('');
                if (del_dic[name]){
                    del_dic[name].push(num)}
                else {del_dic[name]=[num]}
            }
            //剛才被點中的,再次點擊,取消顏色
            else if($(this).hasClass('success')){
                $(this).removeClass('success');
            }
            //沒被選中的,點擊變顏色
            else {
                $(this).addClass('success');
            }
        });
        //保存的點擊事件
        $('.tijiao').click(function () {
            //循環所有的td標簽,然后把擁有success類的標簽的值放入add_dic
            $('td').each(function () {
                var num=$(this).children('span').first().attr('class');
                var name=$(this).parent().attr('class');
                if($(this).hasClass('success')){
                    if (add_dic[name]){
                        add_dic[name].push(num)}
                    else {add_dic[name]=[num]}
                }});
            //把add_dic,not_add_dic加入一個列表中,最后把當前選擇的日期也放進去
            var date=$('.left').first().val();
            //用ajax請求,把列表發送到后端
            $.ajax({
                url:'',
                type:'post',
                data: {'add_dic':JSON.stringify(add_dic),'del_dic':JSON.stringify(del_dic),'date':JSON.stringify(date),'csrfmiddlewaretoken':$('[name="csrfmiddlewaretoken"]').val()},
                success: function (res) {
                    console.log(res);
                    location.href='/houseorder/?time='+res
                }
            })
        })
    </script>
{% endblock %}

  3,后端代碼

def houseorder(request):
    date = request.GET.get('time')
    now = time.strftime('%Y-%m-%d', time.localtime(time.time()))
    if request.is_ajax():                #這是對ajax請求的處理
        add_dic = json.loads(request.POST.get('add_dic'))
        del_dic = json.loads(request.POST.get('del_dic'))
        date = json.loads(request.POST.get('date'))
        date =date or now
        if del_dic:                   #拿到要刪除的字典,然后刪除
            for key, value in del_dic.items():
                for ele in value:
                    Order.objects.filter(date=date, user_id=request.user.id, house_id=int(key),
                                         time=int(ele)).delete()
        if add_dic:                   #這是拿到添加的字典,然后添加
            for key, value in add_dic.items():
                for i in value:
                    Order.objects.create(date=date, user_id=request.user.id, house_id=int(key), time=int(i))
        return HttpResponse(date)
    #點擊日歷提交的post請求
    if request.method == 'POST':
        date = request.POST.get('time')
  這是構建頁面需要的數據,比如說表體。。。 date
=date or now username = request.user.name orders = Order.objects.filter(date=date) houses = House.objects.all() choices = times data_list = [] for house in houses: #這就是構建表體數據 data_list.append(mark_safe('<tr class="%s"><td>%s(%s)</td>' % (house.id, house.name, house.size))) for choice in choices: for order in orders: if order.house.id == house.id and choice[0] == order.time: if username==order.user.name: tt = mark_safe('<td class="nn danger"><span class="%s">%s</span></td>' % (choice[0], order.user.name)) break else: tt = mark_safe('<td class="nn warning"><span class="%s">%s</span></td>' % (choice[0], order.user.name)) break else: tt =mark_safe( '<td class="nn"><span class="%s"></span></td>' % choice[0]) data_list.append(tt) data_list.append('</tr>') data = mark_safe(''.join(data_list)) return render(request, 'houseorder.html', locals())

  對於預定類的功能都可以與此雷同,所有就可以用同樣思路完成。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM