微信小程序---投票神器

来文章源于本人公众号:三角洲科技

如需代码请评论区留言

5.2.1 案例功能详解

麻雀虽小,五脏俱全,本案例有5大功能:

创建新的微投票主题。

我的微投票主题

投票功能(分享、生成二维码)

扫码参与投票

查询微投票结果

界面如下:

5.2.2 案例程序结构

其中index是首页, createvote是创建微投票主题和选项的页面,myvote是我创建过的微投票主题,voteitem是投票页面(含分享、二维码功能),voteresult 是微投票结果页。

5.2.3 案例程序细化详解

首先修改app.json ,设置标题:

然后定义index界面:

这里我们定义了三个button 组件作为微投票的功能菜单,一个是扫描二维码图片,然后跳转到对应的微投票主题上。第二个用来查看我创建过的微投票主题。第三个button用来创建一个新的微投票主题。分别绑定了三个方法,attendvote、myvote和createvote,这些方法将在index.js里实现。

先看看 index.js 里定义了一些变量:

而三个button绑定的方法代码如下:

扫码button调用wx.scanCode方法然后跳转到path上,其他两个button分别调用对应的页面,简单进入即可。

那让我们来实现这两个功能吧,先看“创建我的投票”的界面:

微投票的功能上我们可以设置了3个属性,一个是投票类型,说明微投票是单选,还是可以多选。一个是标题,最后一个是选项,我们会把它设计成可以变化的多个选项,只需要简单的点击 ”添加选项” 按钮就可以。

我们看看页面代码(createvote.wxml),类型和标题:

选项部分的页面代码:

业务方面我们的微投票至少要有2个选项,最多可以有16个选项,所以我们直接写死了前2个name分别为 voteopt1和voteopt2 的input选项 ,而从第三个开始到第十六个就不一样了,我们用block 把整个选项的view包裹起来,并通过op3condition这个变量开关来控制block 是否显示,实现选项的动态显示和隐藏, 达到自定义选项数量的目的。

添加选项的button我们绑定了一个叫addOption 方法,将会在createvote.js里实现:

而整个页面,我们用一个form的组件包裹,然后通过submit来提交到createvote.js 的formSubmit方法上:

我们看看点击“添加选项”后会发生什么:

点击后发现多了个选项3,而且后边还多了个“-” 号,这个减号是我们拿来删除对应某个选项的操作。再点一次“添加选项”:

我们又发现,选项4已经成功添加,同时选项3的 “-” 减号已经消失,这时如何实现的呢?看看代码:

这里就是通过控制对应选项的block上定义的变量op4condition,变更成true来显示,同时把上个选项的“-”减号的变量bt3condition 变成false来隐藏。同理,点击“-” 减号,也可以把本选项隐藏掉,同时把上个选项的“-”减号显示:

j 是页面变量,用来控制对应的选项。点击“-“ 减号后就变成:

这时候,我们选择好类型,填好标题、选项内容后,点击“创建微投票主题“按钮,就可以点生成我们的微投票主题啦:

这里我们的form会调用formSubmit方法,并通过POST提交数据到远程服务器上,如果成功返回,就会弹出弹窗提示相关信息,之后跳转到”我的投票列表“页面上。关于服务器代码和数据库结构,在后面的部分,将会提到。

第二个功能“我的投票主题“:

通过这个界面可以查看我曾经创建的微投票,并且可以通过这个界面去到微投票页面和微投票的结果页。这个页面在 myvote 目录下,页面myvote.wxml很简单:

主要是通过onLoad 方法加载数据:

通过voteItem 去到真正的微投票页面:

通过voteResult 去到微投票的结果页面:

第三个功能“投票“:

在我的投票主题里,点击”投票“,去到微投票真正的投票页(voteitem.wxml):

页面代码如下:

数据通过onLoad 加载(voteitem.js):

选择选项后,点击”投票“,通过form提交:

执行成功返回后,根据返回的状态码,成功的话跳到为投票的结果页,失败的话返回微投票主题列表:

这个页面上,我们还看到一个生成二维码的按钮,点击后将会在页面的下部生成一个二维码的图片,具体实现代码如下,必须先要根据你应用的appid和secret 先获取access_token,然后才能调用api去生成:

在这个页面,我们还实现了分享功能,点击右上角的”...“ 后会弹出:

再点击分享,就会弹出:

其实很简单,只要在需要分享的页面里添加一个方法,把对应页的路径填入path就可以了,但是要注意的是path要用 / 开头:

最后一大功能是:微投票结果页

页面代码也很简单(voteresult.wxml),用个progress来显示比例:

voteresult.js 的加载代码也简单,把微投票的id提交到对应的服务器上,查询返回结果:

服务端控制层部分方法代码(采用了jFinal框架),只是为了示例而用,比较简单,很多逻辑和错误控制都没加上去,请读者见谅:

新增微投票主题:

我的微投票主题列表:

某个微投票详情:

某个微投票结果页:

部分数据结构,也很简单:

微投票主题表:

微投票选项表:

微投票结果表

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 205,236评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,867评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,715评论 0 340
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,899评论 1 278
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,895评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,733评论 1 283
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,085评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,722评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,025评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,696评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,816评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,447评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,057评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,009评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,254评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,204评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,561评论 2 343

推荐阅读更多精彩内容