home.js 8.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241
  1. define(['$', 'template', 'IScroll', 'product', 'user', 'native', 'config', 'address'], function ($, template, IScroll, product, user, native, config, address) {
  2. /*
  3. * 先定义一些模块内用到的function
  4. */
  5. function back(event) {
  6. event.preventDefault();
  7. native.back();
  8. }
  9. /*
  10. * 模块结构:5部分。
  11. * title:题目。
  12. * content:不知道是什么,似乎从没用过。
  13. * 以下可以当作生命周期回调,虽然并不清楚是什么时候回调的……
  14. * init:根据上一个页面传来的pageData初始化本页数据,生成页面,绑定事件。
  15. * beforeopen:接收上一个页面传来的数据、有需要的话重置数据
  16. * afteropen:做一些网络请求。
  17. * beforeclose:
  18. */
  19. return {
  20. title: '壹管家上门服务',
  21. body: '',
  22. init: function (pageData, dtd) {
  23. /* this是什么? */
  24. var $view = this;
  25. var $doc = $(document);
  26. /* 定义按钮事件。
  27. * 为什么不是$(selector).onclick(function)呢?
  28. */
  29. //返回
  30. $.newTouch('.back-button', function (event) {
  31. back.call(this, event);
  32. }, $view);
  33. $view.on('tapBackButton', function (event) {
  34. back.call(this, event);
  35. });
  36. //客服电话
  37. $.newTouch('.service-telephone', function (event) {
  38. event.preventDefault();
  39. native.call('4000328170');
  40. }, $view);
  41. /* 点击产品列表的某一项 */
  42. $.newTouch('.btn-product', function (event) {
  43. event.preventDefault();
  44. var type = parseInt($(this).attr('data-product-type'));
  45. /*
  46. * 这个写法是SPA路由框架规定的。
  47. * $(selector).trigger(event, params)是jQuery的:触发被选元素上的指定事件
  48. */
  49. $doc.trigger('spa:navigate', {
  50. hash: 'placeOrder',
  51. pushData: {
  52. product: product.allList[type-1],
  53. needReset: true
  54. }
  55. });
  56. }, $view);
  57. /* 点击标签
  58. $.newTouch('.btn-product-group', function (event) {
  59. event.preventDefault();
  60. if ($(this).hasClass('global-msg-active')) return;
  61. $(this).addClass('global-msg-active').siblings().removeClass('global-msg-active');
  62. var index = $(this).attr('data-group-index');
  63. switch (index){
  64. case '0':
  65. $('#list0').show().siblings().hide();
  66. break;
  67. case '1':
  68. $('#list1').show().siblings().hide();
  69. break;
  70. case '2':
  71. $('#list2').show().siblings().hide();
  72. break;
  73. case '3':
  74. $('#list3').show().siblings().hide();
  75. break;
  76. }
  77. }, $view); */
  78. // 点击……不知如何说明……
  79. $.newTouch('.btn-action-my-order', function (event) {
  80. event.preventDefault();
  81. $doc.trigger('spa:navigate', {
  82. hash: ''
  83. });
  84. }, $view);
  85. // 个人中心
  86. $.newTouch('.btn-action-coupon', function (event) {
  87. event.preventDefault();
  88. user.checkLogin(function () {
  89. $doc.trigger('spa:navigate', {
  90. hash: 'mine',
  91. pushData: {
  92. needReset: true
  93. }
  94. });
  95. });
  96. }, $view);
  97. /* 招聘
  98. $.newTouch('.btn-action-hire', function () {
  99. event.preventDefault();
  100. $doc.trigger('spa:navigate', {
  101. hash: 'hire'
  102. });
  103. }, $view); */
  104. /* 不知道什么意思。*/
  105. dtd.resolve();
  106. /* 跳转到填写订单页面
  107. function goProductPage(type) {
  108. 如果没登陆会跳转到登录。这个function参数是登陆成功的回调
  109. user.checkLogin(function () {
  110. 预期字段不足 先清除本地数据
  111. if (!user['productVisit'][13]) {
  112. localStorage.removeItem('user_productVisit');
  113. localStorage.removeItem('user_productVisit-time');
  114. user['productVisit'][13] = {
  115. visited: false
  116. }
  117. }
  118. 判断是否是第一次看这个类型。如果不是的话跳转到placeOrder页面
  119. if (user['productVisit'][type]['visited']) {
  120. } else {
  121. 如果是的话跳转到product页面
  122. $doc.trigger('spa:navigate', {
  123. hash: 'product',
  124. pushData: {
  125. type: type,
  126. needReload: true,
  127. fromHome: true
  128. }
  129. });
  130. 并把这个类别的visit属性设置为true
  131. user.productVisit[type].visited = true;
  132. user.setCache('productVisit');
  133. }
  134. // });
  135. } */
  136. /* 跳转到coming页面。
  137. function goComing(type) {
  138. user.checkLogin(function () {
  139. $doc.trigger('spa:navigate', {
  140. hash: 'coming',
  141. pushData: {
  142. productType: type
  143. }
  144. });
  145. });
  146. }*/
  147. /* 不知道这是干什么。离线显示一张图片?
  148. if (!user.activities['visited_offservice0126']) {
  149. // showActivity();
  150. }
  151. function showActivity() {
  152. var imgUrl = 'http://wozhua-others.qiniudn.com/20160126-offservice.png';
  153. var d = new Image();
  154. d.src = imgUrl;
  155. d.onload = function () {
  156. $doc.trigger('spa:openpanel', ['activity', {
  157. content: imgUrl
  158. }]);
  159. }
  160. } */
  161. },
  162. beforeopen: function (pageData, dtd) {
  163. localStorage.removeItem('cart_products');
  164. dtd.resolve();
  165. native.switchPopGesture(true);
  166. },
  167. afteropen: function (pageData, dtd) {
  168. var $view = this;
  169. var $doc = $(document);
  170. /* 如果需要重新加载,就请求服务列表。 */
  171. if (!pageData.pushData.dontNeedReload) {
  172. $doc.trigger('spa:openloader');
  173. /*
  174. * tmodjs:
  175. * 使用模版语法把数据填到html文件,生成一个js文件。
  176. * var tpl = template(html文件路径,数据)
  177. */
  178. var tpl = template('home/index', {
  179. showNavBar: !config.isWX && !config.isChubao,
  180. });
  181. /*
  182. * jQuery:
  183. * 提供一个html元素到js变量的映射,和findViewById一个作用。
  184. * $(selector).???(xxx)
  185. * 其中selector是选择器,对应html的元素、类、id等
  186. * ???是jQuery定义的事件
  187. * xxx是参数,具体是什么取决于事件
  188. *
  189. * 这句的意思是,选取class=".spa-page-body"的元素,把tpl插入其中
  190. */
  191. $('.spa-page-body', $view).html(tpl);
  192. /* 建立IScroll */
  193. setTimeout(function () {
  194. pageData.scroll = new IScroll('#homeScroll');
  195. }, 500);
  196. // product.getListAll(user.id, function (res) {
  197. // });
  198. address.getList({
  199. request_from: 'weixin',
  200. user_id: user.id
  201. });
  202. user.getCouponList(user.id);
  203. $doc.trigger('spa:closeloader');
  204. }
  205. /* 又是这个。不知道什么玩意…… */
  206. dtd.resolve();
  207. //强制设置首页的上一页是空的,后面再调整框架
  208. pageData.prevPage = $('.spa-page-empty');
  209. },
  210. beforeclose: function (pageData, dtd) {
  211. dtd.resolve();
  212. native.switchPopGesture(false);
  213. }
  214. }
  215. })