当前位置:Gxlcms > JavaScript > 基于jquery实现在线选座订座之影院篇

基于jquery实现在线选座订座之影院篇

时间:2021-07-01 10:21:17 帮助过:4人阅读

先给大家展示效果图(支持源码下载哦):

我们在线购票时(如电影票、车票等)可以自己选座。开发者会在页面上列出座次席位,用户可以一目了然的看到可以选择的座位及支付。本文以电影院购票为例,为您展示如何选座、处理选座数据等。

在这里,我给大家介绍一款基于jQuery的在线选座插件:jQuery Seat Charts,它支持自定义座位类型和价格,支持自定义样式,支持设置不可选的座位,也支持键盘控制座位。

HTML

我们假设进入电影《星际穿越》的选座页面,页面布局请看上面的大图,页面左边将在#seat-map中显示影院的座位布局图,右侧#booking-details显示影片相关信息以及选中的座位信息#selected-seats和票价金额信息,选择座位后确认到支付页面完成支付。



CSS

使用CSS将页面中的各个元素美化,尤其是座位列表布局,为座位状态(已售出、可选座位、已选座位等)设置不同的样式,我们已经整理好CSS代码,当然你可以根据自己项目页面风格自己修改任意CSS代码。



jQuery


jQuery

本实例基于jQuery,所以别忘了要先加载jquery库和选座插件:jQuery Seat Charts。

?
<script type="text/javascript" src="jquery.js"></script>
<script type="text/javascript" src="jquery.seat-charts.min.js"></script>

接下来我们定义好诸如票价,座位区,票数,总计金额之类的元素,然后调用插件:$('#seat-map').seatCharts()。

我们先设置好座位图,一个放映厅的座位是固定好的。在本例中,第三排是过道,以及三四排的右侧空位是出口,最后一排我们设置了情侣座,那么放映厅的布局是这样的:

aaaaaaaaaa
aaaaaaaaaa
__________
aaaaaaaa__
aaaaaaaaaa
aaaaaaaaaa
aaaaaaaaaa
aaaaaaaaaa
aaaaaaaaaa
aa__aa__aa

我们用字母a表示座位,用符号_表示空的,即没有座位,当然你也可以用a,b,c等代表不同等级的座位。

然后定义图例样式,关键是侦探点击事件click():用户点击座位时,如果座位状态为可选(available),那么点击座位后,将座位信息(几排几座)加入到右侧的已选座列表中,并计算总票数和总金额;如果座位状态为已选中(selected),那么再次点击座位后,则会将已选中的座位信息从右侧的座位列表中删除,并将状态设置可选;如果座位状态为已售出(unavailable),则不可点击座位。最后使用get()方法将已售出的座位号状态设置为已售出。

以下是详细代码:

var price = 80; //票价
$(document).ready(function() {
var $cart = $('#selected-seats'), //座位区
$counter = $('#counter'), //票数
$total = $('#total'); //总计金额
var sc = $('#seat-map').seatCharts({
map: [ //座位图
 'aaaaaaaaaa',
 'aaaaaaaaaa',
 '__________',
 'aaaaaaaa__',
 'aaaaaaaaaa',
 'aaaaaaaaaa',
 'aaaaaaaaaa',
 'aaaaaaaaaa',
 'aaaaaaaaaa',
 'aa__aa__aa'
],
legend : { //定义图例
 node : $('#legend'),
 items : [
 [ 'a', 'available', '可选座' ],
 [ 'a', 'unavailable', '已售出']
 ]  
},
click: function () { //点击事件
 if (this.status() == 'available') { //可选座
 $('<li>'+(this.settings.row+1)+'排'+this.settings.label+'座</li>')
  .attr('id', 'cart-item-'+this.settings.id)
  .data('seatId', this.settings.id)
  .appendTo($cart);
 $counter.text(sc.find('selected').length+1);
 $total.text(recalculateTotal(sc)+price);
 return 'selected';
 } else if (this.status() == 'selected') { //已选中
 //更新数量
 $counter.text(sc.find('selected').length-1);
 //更新总计
 $total.text(recalculateTotal(sc)-price);
 //删除已预订座位
 $('#cart-item-'+this.settings.id).remove();
 //可选座
 return 'available';
 } else if (this.status() == 'unavailable') { //已售出
 return 'unavailable';
 } else {
 return this.style();
 }
}
});
//已售出的座位
sc.get(['1_2', '4_4','4_5','6_6','6_7','8_5','8_6','8_7','8_8', '10_1', '10_2']).status('unavailable');
});
//计算总金额
function recalculateTotal(sc) {
var total = 0;
sc.find('selected').each(function () {
total += price;
});
return total;
}

以上代码使用jquery实现在线选座订座之影院篇,希望大家喜欢!


人气教程排行