报名问卷组件

优质
小牛编辑
128浏览
2023-12-01

Mudu.Room.Signup 报名问卷组件

获取报名问卷配置

Mudu.Init(41988, function () {
    console.log('Mudu Web Sdk 初始化成功')

    // 获取当前频道正在使用的问卷数据, 需要在频道初始化完成后调用
    Mudu.Room.Signup.GetUsingSignup(function(dataStr){
        // data 数据结果如下表所示
        var data = JSON.parse(dataStr); 
    });

    // 监听问卷的使用状态变更, 需要在频道初始化完成后调用
    Mudu.MsgBus.On('Signup.Status.Change', function(dataStr) {
        var data = JSON.parse(dataStr);
        console.log(data.status); // boolean 启用或关闭问卷
        console.log(data.position); // number 0表示内置问卷;1表示前置问卷
        console.log(data.question_id); // string 问卷的id

        // 根据业务逻辑决定是否重新调用Mudu.Room.Signup.GetUsingSignup方法 或者关闭问卷的弹窗
    });
  }
)
data 数据结构说明
字段说明类型
errcode返回状态码(见页面底部)number
msg返回结果的描述string
page_before使用中的前置问卷signupItem[] (signupItem 结构如下)
page_in使用中的内置问卷signupItem[] (signupItem 结构如下)
signupItem 数据结构说明
字段说明类型
question_id问卷idstring
name问卷名称string
position问卷位置,如下:
0 表示内置问卷
1 表示 前置问卷
number
desc问卷的描述string
status问卷的开启状态, 如下:
0 表示未开启
1 表示 已开启
number
dialog_mode内置问卷的弹窗方式
0 表示由观众手动点击弹窗
1 表示立即弹窗
number
columns问卷的表单内容formItem[] (formItem 结构如下)
privacy_url隐私协议地址string
formItem 数据结构说明
字段说明类型
type'nickname':昵称
'phone':手机号
'privacyPolicy':隐私政策
'input':单行文本回复
'textarea':多行文本回复
'question':选择题
'questionAnswer':问答题
string
name题目的显示名称或题目名称string
must是否必填(true为必填, false为非必填)boolean
multi_select选择题是否为多选boolean
allow_fill_by_self选择题是否允许填写答案(true为允许,false为不允许)boolean
remind是否开启短信提醒(仅当type为phone时存在)boolean
sendSms是否开启发送验证码(仅当type为phone时存在)boolean
startTime直播开始时间(仅当type为phone时存在)string
ahead直播前多少分钟发送提醒(仅当type为phone时存在)number
options选择题的选项列表 {A: '选项a', B: '选项b', ...}object

手机短信验证

操作流程如下
  • 初始化 智能人机校验 模块
  • 校验成功后,获取到token、sessionId、sig参数
  • 使用上述参数在内的数据 调用发送短信接口
智能人机校验
Mudu.Room.Signup.InitCaptcha({
    //声明智能验证需要渲染的目标元素ID。
    renderTo: '#sc',
    //智能验证组件的宽度。
    width: 300,
    //智能验证组件的高度。
    height: 42,
    //前端智能验证通过时会触发该回调参数。您可以在该回调参数中将请求标识(token)、会话ID(sessionid)、签名串(sig)字段记录下来,随业务请求一同发送至您的服务端调用验签。
    success: function(data) {
        // 以下数据是发送短信接口必须的参数
        console.log(data.token);
        console.log(data.sessionId);
        console.log(data.sig);
    },
    fail: function() {
        // 可以在这里调用ResetCaptcha方法进行重置
        console.log('ic error');
    },
    isH5: false, // 非必须 boolean 是否为H5应用,已默认自动检测,也可手动指定
})
发送问卷的手机验证码

注: 发送短信接口每个页面1分钟内只能调用一次, 且发送短信会产生相应的费用

Mudu.Room.Signup.SendSmsRequest({
        signupId: 'xxx', // 必须 string 当前问卷的question_id
        sig, sessionId, token, // 必须 string 人机智能验证成功回调的数据,见上一步success方法
        phone_number, // 必须 string 手机号码
        isH5: false, // 非必须 boolean 是否为H5应用,已默认自动检测,也可手动指定
    },function (response) {
        // response中 错误码见页面底部
        response = JSON.parse(response)
        console.log(response)
    }
)
重置人机智能验证
// 必须在Mudu.Room.Singup.InitCaptcha方法调用后才能使用
// 使用场景如:表单校验失败后,需要重新进行校验的场景
Mudu.Room.Signup.ResetCaptcha();

提交报名表单

// 提交表单数据
Mudu.Room.Signup.SubmitSingup({
        code: '8909', // 必须 string 手机验证码,若无,则为空字符串 
        signupId: 'dfzvda', // 必须 string 问卷id 
        columns: [ // 必须 columns为question及其答案数组
            {type: 'phone', 'name': '手机号', text: '18099998888'},
            {type: 'nickname', 'name': '姓名', text: '目睹君'},
            {type: 'privacyPolicy', 'name': '隐私政策', text: '1'},
            {type: 'question', 'name': '你喜欢听哪些歌手', selects: ['A', 'B', 'D'], text: 'Coldplay' }
        ],
    }, function (response) {
        // response 中对应的错误码见页面底部
        response = JSON.parse(response)
        console.log(response)
    }
)
提交表单时columns item 数据结构说明
名称说明类型
typequestion的类型(nickname为昵称, phone为手机号,privacyPolicy为隐私政策 input为单行文字, question为选择题, questionAnswer为问答题)string
namequestion的显示名称或题目名称string
selects观众选择题所选择的项array
text昵称、手机号、单行文字、多行文字、的答案,或者观众选择题的自填答案string

errcode 错误码列表

errcode说明
1000成功
5601参数错误
5602系统繁忙,请稍后再试
5603无效数据
5604重复操作
5605外部请求错误
5606外部响应错误
5607不允许的操作
5608参数格式错误
5609系统繁忙,请稍后再试~
5612创建文件出错
5613保存文件出错
5614用户信息错误
5615人机验证错误
5616验证码错误次数超过5次
5617验证码错误
5618验证码过期
5619问卷关闭
5620获取用户权限列表失败
5621添加用户权限失败
5622发送短信失败
5699短信发送频率过高