【微信小程序】发布投票与用户投票完整讲解

这篇具有很好参考价值的文章主要介绍了【微信小程序】发布投票与用户投票完整讲解。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

目录

前言

       组件功能示例

一、数据库

二、后端接口定义

三、前端准备

3.1 定义连接接口

3.2 Vant Weapp UI 组件库

3.3 授权登录与相关工具

四、小程序编写

4.1 投票组件

WXML

WXSS

JSON

WXJS

效果展示讲解:

4.2  发布投票组件

WXML

WXSS

JSON

WXJS

效果展示讲解:


前言

        本次主要讲解的是在会议系统中完整投票功能,首先建立思维流程:

  1. 先必须要有会议数据,而会议要由发布、审核、待开等,到开启会议后才能进行发布投票功能。
  2. 发布的投票必须要用户进行登录才可投票
  3. 而用户能够查询所有投票以及已投票或结束的投票

总结非常简单,如果要我们去实现,这时候就有许多问题:

  • 需要编写复杂的sql和查询
  • 需要多样化的组件并实现数据交互
  • 需要分析流程与执行顺序

        如果这些都需要自己独立完成,很多东西还要自己去研究测试,不仅要走许多弯路还得花很多时间和心思。嗯...我就是这样过来的,这篇也是爆肝凌晨几点完成的。话不多说,现在就开始进入正题。

组件功能示例

【微信小程序】发布投票与用户投票完整讲解,微信小程序,java,微信小程序,小程序

一、数据库

投票功能是建立在会议和用户之上的,所以先介绍一下这两个表:

t_oa_meeting_info:

【微信小程序】发布投票与用户投票完整讲解,微信小程序,java,微信小程序,小程序

wx.user: 

【微信小程序】发布投票与用户投票完整讲解,微信小程序,java,微信小程序,小程序

主要关注会议状态(state字段)

 

1、存储发布的投票表:

【微信小程序】发布投票与用户投票完整讲解,微信小程序,java,微信小程序,小程序

2. 用户投票信息表:

【微信小程序】发布投票与用户投票完整讲解,微信小程序,java,微信小程序,小程序

sql预览:

#查询进行中的投票
select * from t_oa_meeting_option where meetingId = (select id from t_oa_meeting_info where state = 5)

#查询结束会议的投票
select * from t_oa_meeting_option where meetingId = (select id from t_oa_meeting_info where state = 6)

#查询票数
select count(*) from t_oa_meeting_vote where optionId = 2

#查询已投的的票
select * from t_oa_meeting_option where id = (select optionId from t_oa_meeting_vote where personId = 5)

 

二、后端接口定义

方法功能:注释 

WxInfoController :会议数据

package com.ycxw.ssm.wxcontroller;

import com.ycxw.ssm.mapper.InfoMapper;
import com.ycxw.ssm.model.Info;
import com.ycxw.ssm.util.ResponseUtil;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

import java.util.HashMap;
import java.util.List;
import java.util.Map;

/**
 * @author 云村小威
 * @create 2023-10-26 22:28
 */
@RestController
@RequestMapping("/wx/info")
public class WxInfoController {
    @Autowired
    private InfoMapper infoMapper;
    @RequestMapping("/list")
    public Object list (Info info){
        List<Info> list = infoMapper.list(info);
        Map<Object, Object> data = new HashMap<Object, Object>();
        data.put("infoList",list);
        return ResponseUtil.ok(data);
    }

    //查询所有进行中的会议
    @RequestMapping("/listState")
    public Object listState (Info info){
        info.setState(4);
        List<Info> list = infoMapper.list(info);
        Map<Object, Object> data = new HashMap<Object, Object>();
        data.put("listState",list);
        return ResponseUtil.ok(data);
    }

    //修改会议状态
    @RequestMapping("/state")
    public Object updateState (Info info){
        infoMapper.updateByPrimaryKeySelective(info);
        return ResponseUtil.ok();
    }
}

 

WXOptionController:投票数据

package com.ycxw.ssm.wxcontroller;

import com.ycxw.ssm.mapper.OptionMapper;
import com.ycxw.ssm.model.Option;
import com.ycxw.ssm.util.ResponseUtil;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

import java.util.HashMap;
import java.util.List;
import java.util.Map;

/**
 * @author 云村小威
 * @create 2023-10-26 22:28
 */
@RestController
@RequestMapping("/wx/option")
public class WXOptionController {
    @Autowired
    private OptionMapper optionMapper; //正在投票信息

    //查询所有投票
    @RequestMapping("/list")
    public Object list() {
        List<Option> list = optionMapper.list();
        Map<Object, Object> data = new HashMap<Object, Object>();
        data.put("voteList", list);
        return ResponseUtil.ok(data);
    }

    /*发布投票*/
    @RequestMapping("/add")
    public Object save(Option option) {
        //发起投票
        optionMapper.insertSelective(option);
        return ResponseUtil.ok();
    }

    //查询所有结束的投票
    @RequestMapping("/over")
    public Object selectOverVote() {
        List<Option> list = optionMapper.selectOverVote();
        Map<Object, Object> data = new HashMap<Object, Object>();
        data.put("overList", list);
        return ResponseUtil.ok(data);
    }

    //查询所有已投票的信息
    @RequestMapping("/already")
    public Object selectByAlready(Long personId) {
        List<Option> list = optionMapper.selectByAlready(personId);
        Map<Object, Object> data = new HashMap<Object, Object>();
        data.put("alreadyList", list);
        return ResponseUtil.ok(data);
    }

    //模糊查询投票信息
    @RequestMapping("/search")
    public Object SearchVote(Option option) {
        List<Option> list = optionMapper.SearchVote(option);
        Map<Object, Object> data = new HashMap<Object, Object>();
        data.put("searchList", list);
        return ResponseUtil.ok(data);
    }
}

WXVoteController:用户投票数据

package com.ycxw.ssm.wxcontroller;

import com.ycxw.ssm.mapper.VoteMapper;
import com.ycxw.ssm.model.Vote;
import com.ycxw.ssm.util.ResponseUtil;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

import java.util.HashMap;
import java.util.Map;

/**
 * @author 云村小威
 * @create 2023-10-26 22:28
 */
@RestController
@RequestMapping("/wx/vote")
public class WXVoteController {
    @Autowired
    private VoteMapper voteMapper;

    //查询选项正在投票的会议的票数
    @RequestMapping("/ticket")
    public Object selectByOptionId(Long optionId) {
        Long i = voteMapper.selectByOptionId(optionId);
        Map<Object, Object> data = new HashMap<Object, Object>();
        data.put("ticket", i);
        return ResponseUtil.ok(data);
    }

    //投票
    @RequestMapping("/add")
    public Object insertSelective(Vote record) {
        int i = voteMapper.insertSelective(record);
        Map<Object, Object> data = new HashMap<Object, Object>();
        data.put("ok", i);
        return ResponseUtil.ok(data);
    }

}

 

三、前端准备

3.1 定义连接接口

这里只列出本次需要实现功能的接口 

// 以下是业务服务器API地址
// 本机开发API地址
var WxApiRoot = 'http://localhost:8080/oapro/wx/';

module.exports = {
  AuthLoginByWeixin: WxApiRoot + 'auth/login_by_weixin', //微信登录
  AuthLogout: WxApiRoot + 'auth/logout', //账号登出
  MettingInfoState: WxApiRoot + 'info/listState', //所有进行中的会议
  VoteInfos: WxApiRoot + 'option/list', //所有发布投票的会议
  SearchVote: WxApiRoot + 'option/search', //搜索投票信息
  UpdateState: WxApiRoot + 'info/state', //修改会议状态
  MeetingAddVote: WxApiRoot + 'option/add', //发布投票
  OverVote: WxApiRoot + 'option/over',//所有结束的会议
  AlreadyVote: WxApiRoot + 'option/already',//所有已投的会议
  SelectTicket: WxApiRoot + 'vote/ticket',//查询票数
  AddTicket: WxApiRoot + 'vote/add',//投票
};

3.2 Vant Weapp UI 组件库

本次主要使用 Vant Weapp UI 组件搭建的,学习这个很简单,根据文档安装操作即可:进入 Vant Weapp UI 文档

3.3 授权登录与相关工具

进入 【微信小程序】授权登录流程解析

主要为了了解微信授权登录的流程和原理,方便更好理解后面的知识。

四、小程序编写

4.1 投票组件

WXML

        这里是利用 vant weapp 组件布局的,里面包括搜索框、tab列表、弹窗、以及一个定位的图片按钮,用于进入发布投票页面。 

<!--pages/vote/list/list.wxml-->
<view style="height: 15rpx;"></view>
<!-- 搜索框 -->
<van-search value="{{ search }}" placeholder="请输入搜索关键词" show-action bind:change="Search" bind:search="onSearch" bind:cancel="onCancel" />
<view style="height: 20rpx;"></view>
<!-- tabs列表 -->
<van-tabs type="card" color="#1989fa">
  <!-- VoteALL -->
  <van-tab title="进行中">
    <van-divider dashed contentPosition="center" customStyle="color: #1989fa; border-color: #1989fa;">
      投一票
    </van-divider>
    <view class="oaFlex">
      <block wx:for-items="{{VoteAll}}" wx:for-item="item" wx:key="item.id">
        <view class="list" data-id="{{item.id}}" bindtap="open_vote" data-text="{{item.title}}">
          <view class="list-detail">
            <view class="list-title"><text>{{item.title}}</text></view>
            <!-- <view class="list-tag">
              <view class="join al-center"><text class="list-num">0</text> 人已投</view>
            </view> -->
          </view>
          <view class="list-img al-center">
            <image class="video-img" mode="scaleToFill" src="{{item.picture}}"></image>
          </view>
        </view>
      </block>
    </view>
  </van-tab>
  <!-- publishVote  -->
  <van-tab title="已结束">
    <view style="height: 50rpx;"></view>
    <view class="oaFlex">
      <block wx:for-items="{{OverVote}}" wx:for-item="item" wx:key="item.id">
        <view class="list" data-id="{{item.id}}" bindtap="open_vote" data-text="{{item.title}}">
          <view class="list-detail">
            <view class="list-title"><text>{{item.title}}</text></view>
            <!-- <view class="list-tag">
              <view class="join al-center"><text class="list-num">0</text> 人已投</view>
            </view> -->
          </view>
          <view class="list-img al-center">
            <image class="video-img" mode="scaleToFill" src="{{item.picture}}"></image>
          </view>
        </view>
      </block>
    </view>
  </van-tab>
  <!-- AlreadyVote  -->
  <van-tab title="已投票">
    <view style="height: 50rpx;"></view>
    <view class="oaFlex">
      <block wx:for-items="{{AlreadyVote}}" wx:for-item="item" wx:key="item.id">
        <view class="list" data-id="{{item.id}}" bindtap="open_vote" data-text="{{item.title}}">
          <view class="list-detail">
            <view class="list-title"><text>{{item.title}}</text></view>
            <!-- <view class="list-tag">
              <view class="join al-center"><text class="list-num">0</text> 人已投</view>
            </view> -->
          </view>
          <view class="list-img al-center">
            <image class="video-img" mode="scaleToFill" src="{{item.picture}}"></image>
          </view>
        </view>
      </block>
    </view>
  </van-tab>
</van-tabs>
<!-- 投票弹出框 -->
<van-dialog use-slot title="投一票" show="{{ showVote }}" show-cancel-button confirm-button-open-type="getUserInfo" bind:close="onClose" bind:getuserinfo="getUserInfo">
  <view style="height: 25rpx;"></view>
  <van-notice-bar scrollable="{{true}}" color="#1989fa" background="#ecf9ff" left-icon="volume-o" text="{{text}}" />
  <view style="height: 15rpx;"></view>
  <van-cell-group inset>
    <van-cell title="当前票数">
      <van-stepper disable-input="{{true}}" value="{{ ticket }}" bind:change="onChange" max="{{ticket+1}}" min="{{ticket}}" />
    </van-cell>
  </van-cell-group>
</van-dialog>
<!-- 发布投票图片按钮 -->
<view style="position:fixed; bottom:10px;width: 150rpx;right: 10px;">
  <van-image bindtap="open_publishVote" round width="5rem" height="5rem" src="/static/images/add.png" />
</view>

WXSS

/* pages/vote/list/list.wxss */
.oaFlex {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.list {
  width: 360px;
  display: flex;
  flex-direction: column;
  align-items: center;
  background-color: rgb(228, 240, 253);
  border-bottom: 2px solid #d9dbe2;
  margin-bottom: 25px;
}

.video-img {
  width: 360px;
  height: 160px;
}

.list-detail {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.list-title {
  margin-top: 10px;
  height: 30px;
  font-size: 13pt;
  color: #333;
  font-weight: bold;
}

.list-info {
  color: #aaa;
}

.list-num {
  color: red;
  /* font-weight: 700; */
}

.join {
  padding: 0px 0px 0px 10px;
  color: #aaa;
}

.state {
  margin: 0px 6px 0px 6px;
  border: 1px solid #4083ff;
  color: #4083ff;
  padding: 3px 5px 3px 5px;
}

.list-tag {
  padding: 10px 0px 10px 0px;
  display: flex;
  align-items: center;
}

JSON

{
  "navigationBarTitleText": "投票",
  "usingComponents": {
    "van-row": "@vant/weapp/row/index",
    "van-col": "@vant/weapp/col/index",
    "van-search": "@vant/weapp/search/index",
    "van-switch": "@vant/weapp/switch/index",
    "van-dialog": "@vant/weapp/dialog/index",
    "van-tab": "@vant/weapp/tab/index",
    "van-tabs": "@vant/weapp/tabs/index",
    "van-divider": "@vant/weapp/divider/index",
    "van-image": "@vant/weapp/image/index",
    "van-stepper": "@vant/weapp/stepper/index",
    "van-cell": "@vant/weapp/cell/index",
    "van-cell-group": "@vant/weapp/cell-group/index",
    "van-notice-bar": "@vant/weapp/notice-bar/index"
  }
}

WXJS

// pages/vote/list.js
var app = getApp();
const api = require('../../../config/api');
const util = require('../../../utils/util.js');

Page({
  /**
   * 页面的初始数据
   */
  data: {
    VoteAll: [], //进行中的投票
    OverVote: [], //已结束
    AlreadyVote: [], //已投票
    checked: false, //禁止投票开关
    showVote: false, //投票弹出框开关
    text: '', //投票标题
    ticket: 0, //票数
    ticket2: 0, //投票后的票数
    search: '', //搜索值
    optionId: 0, //投票id
    personId: 0, //用户id
  },
  /*监听搜索输入框的值*/
  Search(event) {
    this.setData({
      search: event.detail
    })
  },
  /*输入框搜索商品*/
  onSearch() {
    var that = this;
    //调用查询接口
    util.request(api.SearchVote, {
      title: that.data.search
    }).then(res => {
      //如果搜索字段为空,就刷新界面
      if (that.data.search == '') {
        this.onShow();
      } else {
        this.setData({
          VoteAll: res.data.searchList
        });
      }
    }).catch(res => {
      console.log('服器没有开启,使用模拟数据!')
    })
  },

  //获取全部投票信息
  loadVoteInfos() {
    util.request(api.VoteInfos).then(res => {
      this.setData({
        VoteAll: res.data.voteList
      });
    }).catch(res => {
      console.log('服器没有开启,使用模拟数据!')
    })
  },
  //获取全部已结束投票信息
  loadOverVote() {
    util.request(api.OverVote).then(res => {
      this.setData({
        OverVote: res.data.overList
      });
    }).catch(res => {
      console.log('服器没有开启,使用模拟数据!')
    })
  },
  //获取全部已投票的信息
  loadAlreadyVote() {
    util.request(api.AlreadyVote, {
      personId: this.data.personId
    }).then(res => {
      this.setData({
        AlreadyVote: res.data.alreadyList
      });
    }).catch(res => {
      console.log('服器没有开启,使用模拟数据!')
    })
  },

  //发布投票点击事件
  open_publishVote: function () {
    wx.navigateTo({
      url: '/pages/meeting/add/add',
    })
  },

  //投票弹窗点击事件
  open_vote(event) {
    var itemId = event.currentTarget.dataset.id; //投票id
    var itemText = event.currentTarget.dataset.text; //投票主题
    util.request(api.SelectTicket, {
      optionId: itemId
    }).then(res => {
      this.setData({
        text: itemText,
        showVote: true,
        ticket: res.data.ticket,
        optionId: itemId
      });
    }).catch(res => {
      console.log('服器没有开启,使用模拟数据!')
    })

  },
  //投票弹窗关闭事件
  onClose() {
    this.setData({
      showVote: false
    });
  },
  //票数绑定
  onChange(event) {
    // 用户投的票
    this.setData({
      ticket2: event.detail
    });
    console.log(this.data.ticket); //原票数
    console.log(this.data.ticket2); //新票数
  },

  // 投票确认事件
  getUserInfo(event) {
    let ticket = this.data.ticket2;
    let userInfo = wx.getStorageSync('userInfo');;
    // 构造发布投票请求参数
    const putVote = {
      optionId: this.data.optionId,
      personId: userInfo.userId
    };
    //对比如果没增长就代表没投票,并且为登录状态
    if (this.data.ticket == ticket || userInfo.userId == 0) {
      wx.showToast({
        title: '暂未投票哦',
        icon: 'error',
        duration: 2000,
        mask: true //显示透明蒙层,防止触摸穿透
      });
    } else {
      util.request(api.AddTicket, putVote).then(res => {
        console.log(res);
        wx.showToast({
          title: '投票成功',
          icon: 'sucess',
          duration: 2000,
          mask: true //显示透明蒙层,防止触摸穿透
        });
        this.onShow();
      }).catch(res => {
        console.log('服器没有开启,使用模拟数据!')
      })
    }
  },


  /**
   * 生命周期函数--监听页面加载
   */
  onLoad(options) {

  },


  /**
   * 生命周期函数--监听页面显示
   */
  onShow() {
        // 从本地缓冲拿取用户id
        let userInfo = wx.getStorageSync('userInfo');
        this.setData({
          personId: userInfo.userId
        });
    this.loadVoteInfos();
    this.loadOverVote();
    this.loadAlreadyVote();
  },

  /**
   * 生命周期函数--监听页面隐藏
   */
  onHide() {

  },

  /**
   * 生命周期函数--监听页面卸载
   */
  onUnload() {

  },

  /**
   * 页面相关事件处理函数--监听用户下拉动作
   */
  onPullDownRefresh() {

  },

  /**
   * 页面上拉触底事件的处理函数
   */
  onReachBottom() {

  },

  /**
   * 用户点击右上角分享
   */
  onShareAppMessage() {

  }
})

 

效果展示讲解:

1、查询当前登录的用户id,获取已投票和未投票信息,分别存储不同数组进行遍历显示

2、通过数据投票主题关键字进行模糊查询

3、点击投票列表进入弹窗,显示投票主题和该票数,利用进步器选择加减投票

4、必须加一票和登录后才能投票成功,并刷新界面

🌟更多解释请研究js代码

【微信小程序】发布投票与用户投票完整讲解,微信小程序,java,微信小程序,小程序

 

4.2  发布投票组件

WXML

这里用到了图片上传和下拉会议列表

<!--pages/meeting/add/add.wxml-->
<view class="img">
  <image class="upload_img" src="{{imageUrl=='' ? '/static/images/uploadimg.png':imageUrl }}" mode="aspectFit" bindtap="handleUploadImage"></image>
  <input hidden="true" type="text" name="images" value="{{imageUrl}}" />
</view>
<view style="height: 10px;"></view>
<van-cell-group>
  <van-field model:value="{{ title }}" placeholder="请输入投票主题" label="主题" border="{{ true }}" />
</van-cell-group>
<view style="height: 10px;"></view>
<!-- 会议列表 -->
<van-dropdown-menu active-color="#1989fa">
  <van-dropdown-item value="{{ value }}" options="{{ option }}" bind:change="onDropdownMenuChange" />
</van-dropdown-menu>
<view style="height: 300px;"></view>
<van-row>
  <van-col offset="8" span="8">
    <van-button plain hairline icon="add-square" type="info" style="margin-top: 25px;" bind:tap="handleVote" size="large">发起投票</van-button>
  </van-col>
</van-row>

 

WXSS

/* pages/meeting/add/add.wxss */
.img {
  margin-top: 25px;
  height: 480rpx;
}

.upload_img {
  height: 450rpx;
  width: 735rpx;
  box-shadow: 5px 8px rgb(218, 221, 221);
  border-radius: 5rpx;
}

JSON

{
  "navigationBarTitleText": "发起投票",
  "usingComponents": {
    "van-field": "@vant/weapp/field/index",
    "van-uploader": "@vant/weapp/uploader/index",
    "van-row": "@vant/weapp/row/index",
    "van-col": "@vant/weapp/col/index",
    "van-calendar": "@vant/weapp/calendar/index",
    "van-cell": "@vant/weapp/cell/index",
    "van-cell-group": "@vant/weapp/cell-group/index",
    "van-button": "@vant/weapp/button/index",
    "van-picker": "@vant/weapp/picker/index",
    "van-dropdown-menu": "@vant/weapp/dropdown-menu/index",
    "van-dropdown-item": "@vant/weapp/dropdown-item/index"
  }
}

WXJS

// pages/meeting/add/add.js
var app = getApp();
const api = require('../../../config/api');
const util = require('../../../utils/util.js');

Page({
  /**
   * 页面的初始数据
   */
  data: {
    imageUrl: '', //发布投票图片
    option: [{
      text: '选择会议',
      value: 0
    }], //会议选项(该是默认值)
    value: 0, //会议选项id
    optiontext: null, //会议选项标题
    title: '', //投票主题
  },

  //图片选择器
  handleUploadImage() {
    wx.chooseImage({
      count: 1,
      success: (res) => {
        const imagePath = res.tempFilePaths[0];
        // 处理选择的图片路径
        console.log('选择的图片路径:', imagePath);
        this.setData({
          imageUrl: imagePath // 更新图片路径,触发重新渲染
        });
      }
    });
  },

  //获取所有正在进行的会议
  loadMeetingInfos() {
    util.request(api.MettingInfoState).then(res => {
      //定义空数组存储数据库传来的json数据值
      let options = [];
      for (var index in res.data.listState) {
        //获取需要的字段值
        let id = res.data.listState[index].id;
        let title = res.data.listState[index].title;
        //给每个值设置对应的字段存储到数组
        options.push({
          text: title,
          value: id
        });
      }
      this.setData({
        //在option数组的内容后添加新的内容
        option: this.data.option.concat(options)
      });
    }).catch(res => {
      console.log('服器没有开启,使用模拟数据!')
    })
  },

  // 监听菜单选择事件
  onDropdownMenuChange(event) {
    //获取选择的选项值
    let value = event.detail;
    //获取option数组的value与选择的value值相同的数据
    const selectedOption = this.data.option.find(option => option.value === value);
    this.setData({
      //将数据赋值到变量中进行存储
      optiontext: selectedOption.text,
      value: selectedOption.value
    });
  },

  //发布投票
  handleVote() {
    // 获取页面中的数据
    const picture = this.data.imageUrl;
    const meetingId = this.data.value;
    const title = this.data.title;

    //判断只要有内容为空就不进行发布
    if (picture == '' || meetingId == 0 || title == '') {
      wx.showToast({
        title: '请完善投票内容',
        icon: 'error',
        duration: 2000,
        mask: true //显示透明蒙层,防止触摸穿透
      });
      //阻止运行后面的代码
      return
    }

    // 构造发布投票请求参数
    const requestData = {
      meetingid: meetingId,
      title: title,
      picture: picture
    };

    // 构造修改会议状态请求参数
    const updateData = {
        id: meetingId,
        state:5
    };

    // 发起网络请求,将数据传递给后端
    util.request(api.MeetingAddVote, requestData).then(res => {
      //修改会议状态为开启投票接口
      util.request(api.UpdateState,updateData).then(res => {console.log(res)});
      //获取页面栈返回上一个界面
      const pages = getCurrentPages() //获取页面列表
      const perpage = pages[pages.length - 1] //当前页   
      //刷新页面
      wx.navigateBack({
        delta: 1,
        //返回成功调用函数
        success: function () {
          wx.showToast({
            title: '发布成功',
            icon: 'success',
            duration: 2000,
            mask: true //显示透明蒙层,防止触摸穿透
          });
        }
      })
      //加载界面(用于刷新)
      perpage.onLoad()

      // 可以在这里进行页面跳转或其他操作
    }).catch(res => {
      // 请求失败的处理逻辑
      console.error('数据保存失败', err);
    })
  },

  /**
   * 生命周期函数--监听页面加载
   */
  onLoad(options) {
    this.loadMeetingInfos();
  },

  /**
   * 生命周期函数--监听页面初次渲染完成
   */
  onReady() {

  },

  /**
   * 生命周期函数--监听页面显示
   */
  onShow() {

  },

  /**
   * 生命周期函数--监听页面隐藏
   */
  onHide() {

  },

  /**
   * 生命周期函数--监听页面卸载
   */
  onUnload() {

  },

  /**
   * 页面相关事件处理函数--监听用户下拉动作
   */
  onPullDownRefresh() {

  },

  /**
   * 页面上拉触底事件的处理函数
   */
  onReachBottom() {

  },

  /**
   * 用户点击右上角分享
   */
  onShareAppMessage() {

  }
})

效果展示讲解:

1、首先是一个图片点击事件跳转到发布投票界面

2、进入页面就开始渲染会议列表内容,获取所有会议状态为开启会议的json数据,通过遍历拿取id和标题,按照指定下拉列表组件指定属性进行复制。

3、通过微信提供的图片上传函数,将图片解析成网络路径进行访问和存储

4、最后准备发布投票:

  • 监听下拉列表数据,通过选择的值对原数组的值进行判断从而确定拿取的数据
  • 发布成功后通过获取页面栈返回上级界面,并利用生命周期同时刷新投票界面

🌟更多解释请研究js代码

【微信小程序】发布投票与用户投票完整讲解,微信小程序,java,微信小程序,小程序 

       如你们所见,其实其中许多不足,比如用户投完票后,该选择没有在界面上消除。这里还需要做连表查询投票信息如果存在该发布的投票列表就不会再获取到;还有每当点击投票弹窗确定时,不管是否投了票,是否登录了,它都会调用一次微信登录方法,这个目前还在排查中,不知道是否是某些方法牵引到了登录功能,各位大佬有什么见解欢迎评论区留言🥰文章来源地址https://www.toymoban.com/news/detail-713015.html

到了这里,关于【微信小程序】发布投票与用户投票完整讲解的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 微信小程序没法获取用户地理位置完整解决方案

    微信小程序官方文档提示:自 2022 年 7 月 14 日后发布的小程序,若使用该接口,需要在 app.json 中进行声明,否则将无法正常使用该接口,2022年7月14日前发布的小程序不受影响 为了查找没法定位原因花了半个小时时间认真查看官方文档,最后把wx.getLocation(Object object)接口失败

    2024年02月12日
    浏览(55)
  • uniapp - 微信小程序新版本发布之后用户端怎么更新?updateManager ?

    微信小程序在版本更新后,从上面标题栏进去,发现还是没有更新,存在缓存问题 这就要说到微信小程序更新机制 解决办法--微信提供的wx.getUpdateManager()(我的uniapp)uni.getUpdateManager(),链接:uni.getUpdateManager() | uni-app官网 1)定期检查发现版本更新 微信运行时,会定期检查最近使

    2024年02月06日
    浏览(63)
  • uniapp 微信小程序小票打印机打印教程(超详细讲解) 完整代码,下载后可直接使用

    天梦星官网 (tmxkj.top) https://tmxkj.top/#/   编程资源 直接上代码: html css 目录结构  核心代码代码下载 备注:核心代码在头顶上的zip当中 使用逻辑: 1.用户第一次进来点击连接,只用连接一次,只要用户不关闭程序就不会断开,可接着打印, 2.如果已经连接需要在主动加载函

    2024年02月15日
    浏览(250)
  • 微信小程序-投票功能

    1. 编程语言:微信小程序使用的编程语言是 JavaScript(JS)、WXML、WXSS 和 JSON。 2. 功能描述:实现一个调查统计功能,用户可以通过微信账号登录并进行投票。 3. 输入参数及数据类型:    - 用户微信账号信息:Object    - 调查问题:Array    - 调查选项:Array 4. 预期输出结果及

    2024年04月14日
    浏览(45)
  • 基于微信小程序投票系统(微信小程序毕业设计)

    项目获取请看文章最底下官网 投票系统用户端是基于微信小程序,管理员端是基于web网页端,本系统采用java编程语言,mysql数据库,ssm框架,idea工具进行开发,本系统分为用户和管理员两个角色,用户可以注册登陆微信小程序,查看投票系统公告,查看投票作品,在线投票

    2024年02月11日
    浏览(60)
  • 微信小程序之投票管理

    对于会议管理模块,必不可少的当然就是我们的投票管理,实现真正意义上的无纸化办公,本期博客为大家介绍会议管理模块,包括发布投票及查看各类投票的状态  MyBatis、SpringMVC、VentUI  MyBatis和SpringMVC在博客主页有讲解,可以翻看往期博客 这里简单介绍一下VantUI Vant是一

    2024年02月07日
    浏览(41)
  • 微信小程序投票管理系统:打造智能、便捷的投票体验

    随着社交网络的兴起和移动互联网的普及,人们对于参与和表达意见的需求越来越强烈。在这个背景下,微信小程序投票管理系统应运而生。它为用户提供了一个智能、便捷的投票平台,使用户可以轻松创建和参与各种类型的投票活动。本文将详细介绍微信小程序投票管理系

    2024年02月08日
    浏览(52)
  • 【微信小程序】实现投票功能(附源码)

            Vant Weapp 是一个基于微信小程序的组件库,它提供了丰富的 UI 组件和交互功能,能够帮助开发者快速构建出现代化的小程序应用。Vant Weapp 的设计理念注重简洁、易用和高效,同时提供灵活的定制化选项,以满足开发者不同的需求。         Vant Weapp 包含了多个

    2024年02月08日
    浏览(44)
  • 基于微信小程序的投票评选系统小程序

    文末联系获取源码 开发语言:Java 框架:ssm JDK版本:JDK1.8 服务器:tomcat7 数据库:mysql 5.7/8.0 数据库工具:Navicat11 开发软件:eclipse/myeclipse/idea Maven包:Maven3.3.9 浏览器:谷歌浏览器 小程序框架:uniapp 小程序开发软件:HBuilder X 小程序运行软件:微信开发者 社会发展日新月异

    2024年02月08日
    浏览(55)
  • 微信小程序评选投票系统设计与实现

     博主介绍 :黄菊华老师《Vue.js入门与商城开发实战》《微信小程序商城开发》图书作者,CSDN博客专家,在线教育专家,CSDN钻石讲师;专注大学生毕业设计教育和辅导。 所有项目都配有从入门到精通的基础知识视频课程,免费 项目配有对应开发文档、开题报告、任务书、

    2024年02月04日
    浏览(51)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包