找回密码
 立即注册

扫一扫,访问微社区

查看: 6645|回复: 3

微信小程序学习用demo:日语单词学习;使用LeanCloud

[复制链接]
发表于 2017-1-12 12:50:13 | 显示全部楼层 |阅读模式
作者:The---onE
预览图片:




[mw_shl_code=html,true]// pages/tango/mission.js

//获取应用实例
var app = getApp()

//获取LeanCloud对象
const AV = require('../../libs/av-weapp.js');
var longTapId = ''; //长按记住了的单词ID
var tangoList = {}; //本次任务选择的单词列表
var size = 20; //本次任务选择的单词数
var max = 0; //数据库中符合条件的单词数

var currentTango; //当前单词
var lastTango; //上个单词
var lastFlag; //上个正误

var toneArray = ['◎', '①', '②', '③', '④', '⑤', '⑥', '⑦']; //音调格式

Page({
  //初始数据
  data: {
    review: 0, //本次复习
    study: 0, //本次学习

    last_id: '', //上个ID
    last_flag: '', //上个正误
    last_writing: '', //上个写法
    last_pronunciation: '', //上个读音
    last_part: '', //上个词性
    laset_meaning: '', //上个意思

    id: '', //ID
    pronunciation: '', //读音
    tone: '', //音调
    writing: '加载中', //写法
    part: '', //词性
    meaning: '', //意思
  },
  onLoad: function (options) {
    // 页面初始化 options为页面跳转所带来的参数
    let that = this;
    //获取用户数据
    app.getUserInfo(function (userInfo) {
      //更新数据
      that.setData({
        userInfo: userInfo
      })
    })
  },
  onReady: function () {
    // 页面渲染完成
    let that = this;
    //查询本次任务学习的单词
    var cou = new AV.Query('TangoList');
    cou.count().then(function (count) {
      //符合要求的单词数
      max = count;
      var query = new AV.Query('TangoList');
      //跳过的单词数
      var start = parseInt(Math.random() * max) - size;
      query.skip(start);
      query.limit(size);
      query.find().then(function (result) {
        //将查询到的单词加入列表
        tangoList = result;
        //查询到的单词数量
        size = tangoList.length;
        //选取要显示的单词
        var tango = result[parseInt(Math.random() * size)];
        //显示单词
        that.showNewTango(tango);
      }, function (error) {
        console.error(error);
      });
    }, function (error) {
      console.error(error);
    });
  },
  onShow: function () {
    // 页面显示
  },
  onHide: function () {
    // 页面隐藏
  },
  onUnload: function () {
    // 页面关闭
  },

  //事件处理函数
  //点击记住了
  rememberTap: function () {
    //触发长按事件后不触发点击事件
    if (lastTango != undefined && longTapId == lastTango.id) {
      longTapId = '';
      return;
    }
    wx.showToast({
      title: '记住了',
      icon: 'success',
    });
    //TODO
    //选取新单词
    var tango = tangoList[parseInt(Math.random() * size)];
    //显示新单词
    this.showNewTango(tango, true);
  },
  //点击没记住
  forgetTap: function () {
    var that = this;
    wx.showModal({
      title: '测试',
      content: '没记住',
      success: function (res) {
        if (res.confirm) {
          console.info("确定");
        }
        //选取新单词
        var tango = tangoList[parseInt(Math.random() * size)];
        //显示新单词
        that.showNewTango(tango, false);
      }
    });
    //TODO
  },
  //长按记住了,彻底记住
  foreverTap: function () {
    longTapId = this.data.id;
    wx.showToast({
      title: longTapId,
      icon: 'success',
    });
    //TODO
    //选取新单词
    var tango = tangoList[parseInt(Math.random() * size)];
    //显示新单词
    this.showNewTango(tango, true);
  },
  lastTap: function () {
    this.showNewTango(lastTango);
  },
  //显示新的单词
  showNewTango: function (tango, flag) {
    if (flag != undefined) {
      //将当前单词记为上个单词
      lastTango = currentTango;
      //设置正误格式
      lastFlag = flag;
      var flagStr = lastFlag ? '√' : '×';
      //设置音调格式
      var tone = lastTango.get('Tone');
      var toneStr = '';
      if (tone >= 0 && tone < toneArray.length) {
        toneStr = toneArray[tone];
      }
      //设置词性格式
      var part = lastTango.get('PartOfSpeech');
      if (part.trim().length > 0) {
        part = '[' + part + ']';
      }
      //将上个单词信息显示到界面
      this.setData({
        last_id: lastTango.id, //上个ID
        last_flag: flagStr, //上个正误
        last_pronunciation: lastTango.get('Pronunciation'), //上个读音
        last_tone: toneStr, //上个音调
        last_writing: lastTango.get('Writing'), //上个写法
        last_part: part, //上个词性
        last_meaning: lastTango.get('Meaning'), //上个意思
      })
    } else {
      //没有上个单词则不显示
      lastTango = null;
      this.setData({
        last_id: '', //上个ID
        last_flag: '', //上个正误
        last_pronunciation: '', //上个读音
        last_tone: '', //上个音调
        last_writing: '', //上个写法
        last_part: '', //上个词性
        last_meaning: '', //上个意思
      })
    }
    //将新单词设为当前单词
    currentTango = tango;
    //设置音调格式
    var tone = currentTango.get('Tone');
    var toneStr = '';
    if (tone >= 0 && tone < toneArray.length) {
      toneStr = toneArray[tone];
    }
    //设置词性格式
    var part = currentTango.get('PartOfSpeech');
    if (part.trim().length > 0) {
      part = '[' + part + ']';
    }
    //设置新单词
    this.setData({
      id: currentTango.id, //ID
      pronunciation: currentTango.get('Pronunciation'), //读音
      tone: toneStr, //音调
      writing: currentTango.get('Writing'), //写法
      part: part, //词性
      meaning: currentTango.get('Meaning'), //意思
    })
  },
})[/mw_shl_code]


游客,如果您要查看本帖隐藏内容请回复

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

×

0

主题

245

回帖

63

金钱

新人求带

积分
0
发表于 2017-8-18 09:56:36 | 显示全部楼层
感谢楼主分享

1

主题

42

回帖

157

金钱

咫尺尊享

积分
44
发表于 2017-8-18 13:44:00 | 显示全部楼层
感谢分享
回复

使用道具 举报

0

主题

408

回帖

600

金钱

新人求带

积分
0
发表于 2020-4-20 11:17:26 | 显示全部楼层
我有流量,你有产品,我们就可以合作,有意的个人开发者朋友可以联系微,信,号j i m 2 0 1 8 0 6 8 8,详聊
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|手机版|小黑屋|微信小程序开发|教程|文档|资源汇总_即速论坛 ( 粤ICP备14097199号-1  

GMT+8, 2024-11-25 18:00 , Processed in 0.124600 second(s), 26 queries .

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表