问卷调查设计-SurveyJS的使用(定制)

news2024/10/2 18:18:48

前言

距离上一次记录SurveyJS的文章已经过去大半个月了,也该完结一下子了,正好项目结束,抽出时间记录一下使用SurveyJS过程中的做的一些自定义配置需要哪些方法及属性(这里根据个人项目需要做的一些方法总结,不包含全部,如有遗漏,大家可参考官方文档进行定制)

定制

1. Tab栏新增选项卡

当我们需要新增一个选项卡

ko.components.register('info-tab-template', {template: `<div style="width:100%"> <iframe src="/template_info/" frameborder="0" scrolling="no" width="100%" height="800px"></iframe></div>`
})
const templatesPlugin: any = {activate: () => {}, // 激活时deactivate: () => {return true}
}

creator.addPluginTab('templates', // nametemplatesPlugin,'基本信息', // title'info-tab-template',// componentContent0 // index
) 

2. 控制Tab栏默认选项卡显示隐藏

creatorOptions.value = {showPreviewTab: true,showJSONEditorTab: true,showLogicTab: true,showDesignerTab: true
} 

3. 问题装饰器显示隐藏

creator.onElementAllowOperations.add(function (_, options) {options.allowAddToToolbox = false // 显示或隐藏将当前调查元素配置保存在工具箱中的装饰器。options.allowChangeType = false // 显示或隐藏更改调查元素类型的装饰器options.allowChangeRequired = false // 显示或隐藏使问题成为必需的装饰器。options.allowCopy = false //显示或隐藏复制调查元素的装饰器。options.allowDelete = false // 显示或隐藏删除调查元素的装饰器options.allowDragging = false // 显示或隐藏允许用户拖放调查元素的装饰器options.allowEdit = false; // 显示或隐藏允许用户在设计图面上编辑调查元素属性的装饰器。如果禁用此属性,用户只能在属性网格中编辑调查元素属性。
}) 

4. 工具栏新增按钮

creator.toolbarItems.push(new Action({id: 'custom-back',title: '返回',visible: true,// enabled: true,action: function () {window.location.href = '/question/index'}})
)
creator.toolbarItems.push(new Action({id: 'custom-save',title: '保存',visible: true,// enabled: true,action: function () {updateFun(id, creator)}})
) 

5. 配置问卷只读

/* 整套问卷只读 */
creatorOptions.value = {readOnly: false, //整套问卷是否设置为只读模式
}/* 单独配置问题属性只读*/
creator.onGetPropertyReadOnly.add(function (_, options) {const arr = ['title', 'description', 'text']const data = options.propertyif (arr.indexOf(data.name) === -1 && mode === 'READ_ONLY') {options.readOnly = true}
}) 

6. 单项选择为每一项配置单独的分数

Serializer.addProperty('itemvalue', {name: 'score',type: 'number',category: 'general',default: 0,visibleIndex: 0,onSetValue: (survey: any, value: any) => {survey.setPropertyValue('score', value)}
}) 

7. CSS设置显示隐藏

/* css v-bind绑定变量设置dom元素显示隐藏 */
// 是否允许新增问题
::v-deep(.svc-page__add-new-question) {display: v-bind(isAddItem);
}
// 工具栏显示隐藏
::v-deep(svc-adaptive-toolbox) {display: v-bind(isShowToolbox);
}
//tabs 设置按钮显示隐藏
::v-deep(#svd-settings) {display: v-bind(isShowToolbox);
}
//tabs 属性表格展开收缩按钮显示隐藏
::v-deep(#svd-grid-expand) {display: v-bind(isShowToolbox);
}
// 隐藏保存按钮
::v-deep(#svd-save) {display: none;
} 

8. 更多配置前往官方文档

补充1: 当文档中仍然找不到自己想要的答案时,可前往演示板块查找,说不定有用的藏在这里

补充2: 当官网没有记录时,我们可前往支持中心,看看其他人是否有遇到类似的问题,官方有没有提供相应的解决方案

参考

这里放上项目代码以供参考

<template><div class="surveyCreator_box"><div id="surveyCreator"></div></div>
</template>
<script setup lang="ts"> import { onMounted, ref, reactive, watch, nextTick } from 'vue'
import '@/utils/custom-locale.ts'
import * as ko from 'knockout'
import { SurveyCreator } from 'survey-creator-knockout'
import { Serializer, Action } from 'survey-core'
import { message } from 'ant-design-vue'
import { useRouter } from 'vue-router'
import {apiCreatorSurvey,apiSurveyId,apiUpdateSurveyInfo
} from '@/service/api/survey'
import LocalCache from '@/utils/cache'
const router = useRouter()
const id = ref(LocalCache.getCache('paperId') || '')
let question_text = ref('')
// 添加问题按钮是否需要隐藏
let isAddItem = ref('flex')
// 工具箱面板是否需要隐藏
let isShowToolbox = ref('flex')
// 问卷初始设置
let creator = new SurveyCreator()
let creatorOptions = ref({})
ko.components.register('info-tab-template', {template: `<div style="width:100%"> <iframe src="/survey_info/" frameborder="0" scrolling="no" width="100%" height="800px"></iframe></div>`
})
const templatesPlugin: any = {activate: () => {},deactivate: () => {return true}
}
// 新增基本信息面板
onMounted(async () => {document.documentElement.style.setProperty('--primary', '#6793ff')id.value ? surveyEdit(id.value) : surveyCreate()
})
// Survey相关配置
// 创建问卷
const surveyCreate = () => {creatorOptions.value = {isAutoSave: false,haveCommercialLicense: true,readOnly: false, //整套问卷是否设置为只读模式showSurveyTitle: false,maximumChoicesCount: 4,showSidebar: false,allowModifyPages: false,// 根据问卷是否已创建控制显示隐藏showPreviewTab: true,showJSONEditorTab: true,showLogicTab: true,showDesignerTab: true}creator = new SurveyCreator(creatorOptions.value)creator.makeNewViewActive('templates')// 工具栏自定义creator.toolbarItems.push(new Action({id: 'custom-back',title: '返回',visible: true,// enabled: true,action: function () {window.location.href = '/question/index'}}))creator.toolbarItems.push(new Action({id: 'custom-save',title: '保存',visible: true,// enabled: true,action: function () {createFun(creator)}}))creator.addPluginTab('templates',templatesPlugin,'基本信息','info-tab-template',0)creator.render('surveyCreator')
}
// 创建问卷
const createFun = (creator: any) => {const formState = LocalCache.getCache('formState')if (formState.title == null ||formState.mode == null ||formState.quTypes == []) {message.warn('请检查基本信息中是否有必填选项未填写')} else {apiCreatorSurvey({ ...formState, surveyJson: creator.text }).then((res) => {LocalCache.setCache('paperId', res)message.success('保存成功')})}
}
// 更新问卷
const surveyEdit = async (id: any) => {const json = await apiSurveyId(id)const { mode } = json || 'DEFAULT'const config = {readOnly: false,textModifyOnly: false,notAllowQuDelete: false,notAllowQuTypeChange: false,notAllowQuAdd: false,notAllowQuKeyModify: false}const {readOnly, // 整篇只读textModifyOnly, // 只允许文案修改信息notAllowQuDelete, // 不允许 删除题目notAllowQuTypeChange, // 不允许 改变题型notAllowQuAdd, // 不允许 新增问题notAllowQuKeyModify // 不允许 修改问题变量名} = configcreatorOptions.value = {isAutoSave: false,haveCommercialLicense: true,readOnly: mode === 'READ_ONLY', //整套问卷是否设置为只读模式showSurveyTitle: false,maximumChoicesCount: 4,showSidebar: !(mode === 'BUILD_IN'),allowModifyPages: !(mode === 'BUILD_IN'),// 根据问卷是否已创建控制显示隐藏showPreviewTab: true,showJSONEditorTab: true,showLogicTab: true,showDesignerTab: true}creator = new SurveyCreator(creatorOptions.value)// 回显问卷creator.text = json.surveyJson// 保存问卷// creator.saveSurveyFunc = (saveNo: number, callback: any) => {// question_text.value = creator.text// apiUpdateJson(id, { surveyJson: question_text.value }).then(() => {// message.success('问卷保存成功')// window.history.back()// callback(saveNo, true)// })// }// 针对单项添加分数Serializer.addProperty('itemvalue', {name: 'score',type: 'number',category: 'general',default: 0,visibleIndex: 0,onSetValue: (survey: any, value: any) => {survey.setPropertyValue('score', value)}})// 不允许修改问题变量名(删除数据tab)creator.onPropertyGridSurveyCreated.add(function (_, options) {const dataTab = options.survey.getPanelByName('data')if (dataTab && notAllowQuKeyModify) {dataTab.delete()}})// 活动选项卡更改时调用creator.onActiveTabChanged.add(function (_, options) {})/* 单独配置*/creator.onGetPropertyReadOnly.add(function (_, options) {const arr = ['title', 'description', 'text']const data = options.propertyif (arr.indexOf(data.name) === -1 && mode === 'READ_ONLY') {options.readOnly = true}})// 指定装饰器可用性creator.onElementAllowOperations.add(function (_, options) {// 整套问卷只允许修改文案信息if (mode === 'BUILD_IN') {options.allowAddToToolbox = false // 显示或隐藏将当前调查元素配置保存在工具箱中的装饰器。options.allowChangeType = false // 显示或隐藏更改调查元素类型的装饰器options.allowChangeRequired = false // 显示或隐藏使问题成为必需的装饰器。options.allowCopy = false //显示或隐藏复制调查元素的装饰器。options.allowDelete = false // 显示或隐藏删除调查元素的装饰器options.allowDragging = false // 显示或隐藏允许用户拖放调查元素的装饰器// options.allowEdit = false; // 显示或隐藏允许用户在设计图面上编辑调查元素属性的装饰器。如果禁用此属性,用户只能在属性网格中编辑调查元素属性。}notAllowQuDelete && (options.allowDelete = false) // 不允许删除题目notAllowQuTypeChange && (options.allowChangeType = false) // 不允许改变题型options.allowCopy = false // 显示或隐藏允许用户复制元素的装饰器})// 是否允许新增问题isAddItem.value = notAllowQuAdd || mode === 'BUILD_IN' ? 'none' : 'flex'isShowToolbox.value = notAllowQuAdd || mode === 'BUILD_IN' ? 'none' : 'flex'// 默认显示面板// creator.makeNewViewActive('templates')// 工具栏自定义creator.toolbarItems.push(new Action({id: 'custom-back',title: '返回',visible: true,// enabled: true,action: function () {window.location.href = '/question/index'}}))creator.toolbarItems.push(new Action({id: 'custom-save',title: '保存',visible: true,// enabled: true,action: function () {updateFun(id, creator)}}))creator.addPluginTab('templates',templatesPlugin,'基本信息','info-tab-template',0)creator.render('surveyCreator')
}
// 更新问卷
const updateFun = (id: string, creator: any) => {const formState = LocalCache.getCache('formState')if (formState.title == null ||formState.mode == null ||formState.quTypes == []) {message.warn('请检查基本信息中是否有必填选项未填写')} else {apiUpdateSurveyInfo(id, { ...formState, surveyJson: creator.text }).then(() => {message.success('保存成功')surveyEdit(id)})}
} </script>
<style lang="less" scoped> .surveyCreator_box {width: 100%;height: 100%;.button_class {margin-left: 93.5%;// margin-top: 10px;margin-bottom: 10px;}#surveyCreator {width: 100%;height: 100%;}
}
//是否允许新增问题
::v-deep(.svc-page__add-new-question) {display: v-bind(isAddItem);
}
// 工具栏显示隐藏
::v-deep(svc-adaptive-toolbox) {display: v-bind(isShowToolbox);
}
//tabs 设置按钮显示隐藏
::v-deep(#svd-settings) {display: v-bind(isShowToolbox);
}
//tabs 属性表格展开收缩按钮显示隐藏
::v-deep(#svd-grid-expand) {display: v-bind(isShowToolbox);
}
::v-deep(.svc-creator-tab__content) {min-height: 80vh;
}
::v-deep(.svc-flex-row) {background: none;
}
// 隐藏保存按钮
::v-deep(#svd-save) {display: none;
} </style> 

注: 创建问卷和编辑问卷两个函数中有很大一部分重复代码,这是因为我在应用过程中发现当问卷创建后,再对问卷的个别属性进行单独的修改,并不会发生变化,说明其不支持Vue3下的响应式,所以每修改一次需要我们重新赋值并执行 creator.render('surveyCreator')

代码比较乱,大家挑着看🙂🙂🙂

最后

为大家准备了一个前端资料包。包含54本,2.57G的前端相关电子书,《前端面试宝典(附答案和解析)》,难点、重点知识视频教程(全套)。



有需要的小伙伴,可以点击下方卡片领取,无偿分享

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/369723.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【2023】华为OD机试真题Java-题目0221-AI处理器组合

AI处理器组合 题目描述 某公司研发了一款高性能AI处理器。每台物理设备具备8颗AI处理器,编号分别为0、1、2、3、4、5、6、7。编号0-3的处理器处于同一个链路中,编号4-7的处理器处于另外一个链路中,不通链路中的处理器不能通信,如下图所示。现给定服务器可用的处理器编号数…

这才叫装机必备,这3款高质量电脑软件,内存满了也绝不卸载

闲话少说&#xff0c;直上狠货。 1、quicker quicker是一款指尖电脑工具&#xff0c;使用它实现常用操作&#xff0c;就在手边&#xff0c;点击鼠标中键&#xff0c;即可弹出&#xff0c;位置跟随鼠标&#xff0c;面板窗口的下半部分&#xff0c;它会随当前操作的软件自动加载设…

【Yolov5】保姆级别源码讲解之-推理部分detect.py文件

推理部分之detect.py文件讲解1.下载Yolov5的源码2. 主函数讲解3.文件标头的注释4. main函数的5. run函数5.1 第一块参数部分5.2第二块&#xff0c;传入数据预处理5.3 第三块创建文件夹5.4 第四块 加载模型的权重5.5 第五块 Dataloader 加载模块5.6 第六块 推理部分 Run inferen…

python 魔法方法之 __ slots __

python 魔法方法之 __ slots __ __ slots __ __slots__是python class的一个特殊attribute&#xff0c;能够节省内存空间。正常情况下&#xff0c;一个类的属性是以字典的形式来管理, 每个类都会有__ dict__ 方法。但是我们可以通过 设置 __ slots__ 来将类的属性构造成一个静…

input 子系统

简介 先来了解什么是输入设备&#xff1f; 常见的输入设备有键盘、 鼠标、 遥控杆、 书写板、 触摸屏等等,用户通过这些输入设备与 Linux 系统进行数据交换。 什么是输入系统&#xff1f; 输入设备种类繁多&#xff0c; 能否统一它们的接口&#xff1f; 既在驱动层面统一&…

springboot+vue邯郸地标美食导游平台

设计者应有软件程序开发方面的专业理论基础知识&#xff0c;有一定的分析和解决问题的能力&#xff0c;有一定的收集、整理、信息检索等方面的能力&#xff0c;善于综合、勤于思考&#xff0c;具有一丝不苟&#xff0c;精益求精&#xff0c;刻苦钻研的工作精神&#xff0c;勇于…

基于遗传算法的柔性生产调度研究(Matlab代码实现)

&#x1f468;‍&#x1f393;个人主页&#xff1a;研学社的博客&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5;&#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜密…

S-Paper电子纸在生产车间中的应用

S-Paper电子纸在生产车间中的应用应用背景在传统的制造企业的生产流程中&#xff0c;生产线上的工件信息&#xff0c;加工信息等等在生产前都需要生产车间打印出来&#xff0c;然后再分发至生产线上对应的工件工位&#xff0c;纸张都是使用完后都是作废销毁&#xff0c;这样下来…

SQL零基础入门学习(九)

SQL零基础入门学习&#xff08;八&#xff09; SQL UNION 操作符 UNION 操作符用于合并两个或多个 SELECT 语句的结果集。 请注意&#xff0c;UNION 内部的每个 SELECT 语句必须拥有相同数量的列。列也必须拥有相似的数据类型。同时&#xff0c;每个 SELECT 语句中的列的顺序…

Xmake v2.7.7 发布,支持 Haiku 平台,改进 API 检测和 C++ Modules 支持

layout: post.cn title: “Xmake v2.7.7 发布&#xff0c;支持 Haiku 平台&#xff0c;改进 API 检测和 C Modules 支持” tags: xmake lua C/C package modules haiku cmodules categories: xmake Xmake 是一个基于 Lua 的轻量级跨平台构建工具。 它非常的轻量&#xff0c;没…

Android仿京东金融的数值滚动尺功能

自定义数值滚动尺,这个用的还是挺多的&#xff0c;例如京东金融的通过滚动尺选择金额等,而这次就是高仿京东金融的数值滚动尺。首先看看下效果图&#xff0c;如下&#xff1a;首先先给你们各个变量的含义&#xff0c;以免在后面的讲解中不知变量的意思&#xff0c;代码如下://最…

高/低压供配电系统设计——安科瑞变电站电力监控系统的应用

摘 要&#xff1a;在电力系统的运行过程中&#xff0c;变电站作为整个电力系统的核心&#xff0c;在保证电力系统可靠的运行方面起着至关重要的作用&#xff0c;基于此需对变电站监控系统的特点进行分析&#xff0c;结合变电站监控系统的功能需求&#xff0c;对变电站电力监控系…

载誉而归!昂视荣膺CAIMRS 2023「自动化创新奖」

2月24日&#xff0c;由中国工控网举办的第二十一届自动化及数字化年会在苏州希尔顿酒店隆重举行&#xff0c;昂视受邀参加本次活动。会上&#xff0c;中国工控网发布了第二十一届自动化及数字化年度自动化创新奖&#xff0c;昂视凭借LP8000系列超高精度3D激光轮廓仪斩获“自动化…

浅谈`AI`的那些事-环境搭建

人工智能(AI)-环境搭建 目录导航人工智能(AI)-环境搭建1. 为什么人工智能(AI)首选Python&#xff1f;2. python在AI上的优势2.1 python在AI上的优势2.1.1 语法简单&#xff0c;编码少。2.1.2 内置了几乎所有的AI项目库2.1.3 开源和可用于广泛编程2.2 python的特点3. PyTorch环境…

JVM详解——垃圾回收

如果有兴趣了解更多相关内容的话&#xff0c;可以看看我的个人网站&#xff1a;耶瞳空间 GC&#xff1a;垃圾收集(Gabage Collection)&#xff0c;内存处理是编程人员容易出现问题的地方&#xff0c;忘记或者错误的内存。不当的回收可能会导致程序或系统的不稳定甚至崩溃&…

PHP面向对象05:MVC和smarty

PHP面向对象05&#xff1a;MVC 和 smarty一、MVC思想二、MVC代码设计三、项目单一入口四、Smarty模板技术1. 模板技术原理2. Smarty简单使用3. Smarty配置五、Smarty模板变量六、Smarty内置函数七、Smarty外部函数一、MVC思想 MVC思想&#xff0c;是一种基于面向对象思想形成的…

如何将本地文件自动备份到百度网盘?

如何将本地文件自动备份到百度网盘&#xff1f;说到网盘的使用&#xff0c;大家第一个想到的肯定是百度网盘&#xff0c;百度网盘第一个提出网盘这个概念&#xff0c;相信很多小伙伴都是百度网盘的忠实用户&#xff0c;大家也非常喜欢使用百度网盘来存储文件。为什么百度网盘深…

Apache Hadoop生态部署-kafka单机安装

目录 Apache Hadoop生态-目录汇总-持续更新 一&#xff1a;安装包准备 二&#xff1a;安装与常用配置 2.1&#xff1a;下载解压安装包 2.2&#xff1a;配置环境变量 2.3&#xff1a;配置修改server.properties 三&#xff1a;维护kafka 3.1 编写维护脚本 3.2 启动kafk…

el-cascader 级联选择器懒加载的使用及回显 + 点击任意一级都能返回

需要实现的需求 数据渲染使用懒加载点击任意一级都可返回&#xff0c;不需要一直点到最后一级编辑或者查看功能&#xff0c;回显之前选择的数据 实例解析 dom 元素 <el-cascaderv-model"value":options"options":props"props":key"n…

华为服务器驱动下载及安装

1.服务器技术支持网站 https://support.xfusion.com/support/#/zh/home 2.选择软件下载 3.选择服务器型号 4.选择驱动 5.根据需求选择驱动 例如红帽7.4系统 6.安装驱动 自动安装驱动步骤&#xff1a; 1)使用BMC虚拟光驱挂载onboard_driver_xxx.iso: 2)mount /dev/sr0 /mnt …