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

前言

距离上一次记录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.rhkb.cn/news/51642.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【源码】问卷调查系统的设计与实现

源码分享&#xff01; 源码描述&#xff1a; 1.基本信息维护 2.添加题目类别 3.题目类别管理 4.添加测试题 5.测试题管理 6.添加调查 7.调查管理 8.调查结果列表 技术特点&#xff1a; 1、采用典型的三层架构&#xff0c;代码结构比较清晰 2、界面比较精美&#xff0c;功能比较…

(二)市场调查大赛系列——市场调查问卷设计

目录 一、设计问卷步骤 二、调查问卷题目类型 三、调查问卷答案类型 四、调查问卷的结构 五、调查方案的框架 六、设计问卷的原则 一、设计问卷步骤 将选题具体化、拆分选题确定分析框架 描述性分析解释性分析/推断性分析&#xff0c;找到变量&#xff0c;后续深入研究…

用“平面两点距离”求三角形面积,再用“三角形面积”多边形面积

不小于 3 边的多边形&#xff0c;都可以任一顶点发出的边切分为 n - 2 个三角形。 【学习的细节是欢悦的历程】 Python 官网&#xff1a;https://www.python.org/ Free&#xff1a;大咖免费“圣经”教程《 python 完全自学教程》&#xff0c;不仅仅是基础那么简单…… 地址&am…

对折纸张厚度超过珠峰

对折 0.1 毫米的纸张&#xff0c;循环对折&#xff0c;超过珠峰高度输出对折次数。 【学习的细节是欢悦的历程】 Python 官网&#xff1a;https://www.python.org/ Free&#xff1a;大咖免费“圣经”教程《 python 完全自学教程》&#xff0c;不仅仅是基础那么简单…… 地址&a…

统计字符串字符出现的次数

输入一个字符串&#xff0c;输出字符及相应字符出现的次数。 【学习的细节是欢悦的历程】 Python 官网&#xff1a;https://www.python.org/ Free&#xff1a;大咖免费“圣经”教程《 python 完全自学教程》&#xff0c;不仅仅是基础那么简单…… 地址&#xff1a;https://lqp…

while 循环、if 条件判断,同心协力打造「模拟“春节集五福”活动」程序

while 循环&#xff0c; if 条件判断组合发力解题。根据近两年流行的春节集五福活动&#xff0c;编写一个模块&#xff0c;实现模拟春节集五福的过程。 【学习的细节是欢悦的历程】 Python 官网&#xff1a;https://www.python.org/ Free&#xff1a;大咖免费“圣经”教程《 p…

2023 年 6 月最新绿色软件来了

2023 年6月继续分享实用Windows绿色软件系列&#xff0c;不用安装即可使用&#xff0c;在公众号苏生不惑后台对话框回复关键词 2023616 获取下载地址&#xff0c;之前分享过的都同步到我的博客了 https://sushengbuhuo.github.io/blog LastActivityView 这个工具可以显示用户进…

百度工程师浅谈分布式日志

作者 | 文库基础架构 导读 introduction 我们做软件开发时&#xff0c;或多或少的会记录日志。由于日志不是系统的核心功能&#xff0c;常常被忽视&#xff0c;定位问题的时候才想起它。本文由浅入深的探讨不起眼的日志是否重要&#xff0c;以及分布式架构下的日志运维工具应该…

套用bi模板,轻松搞定各类数据分析报表

bi模板是什么?是一个个提前预设的报表设计&#xff0c;套用后立即生效&#xff0c;轻轻松松搞定bi数据可视化分析报表。bi模板都有哪些类型&#xff1f;怎么套用&#xff1f;以奥威bi数据可视化软件为例&#xff0c;聊聊bi模板的种类和下载使用。 bi模板有哪些&#xff1f; …

企业级Web报表工具告诉你财务要做哪些数据分析

现如今企业财务都实现了电子化&#xff0c;这意味着我们企业的财务人员要将庞大的财务数据录入计算机。现在大部分财务人员都采用传统Excel的方式进行财务报表制作和分析&#xff0c;不但要投入大量的时间和精力&#xff0c;而且易出错、效率低。 最近小编发现了一个企业级Web…

西米支付:微信支付接口(申请与介绍)

据统计&#xff0c;2022年微信全球用户数超12.8亿&#xff0c;其中微信支付使用人数达到6亿&#xff0c;而且微信支付在中国移动支付的市场份额超过40%&#xff0c;无论是在线上购物&#xff0c;还是线下收款&#xff0c;都能看到微信支付的身影&#xff0c;微信支付已经融入到…

IEEE Trans、Journal 和 Letter 的论文格式要求

目录 论文标题 作者 摘要 索引术语/关键词 作者信息脚注 简介 Word模板使用 缩写和缩略语 数学公式 图的制作和提交 IEEE图的类型 多部分图 图形的文件格式 图形尺寸 分辨率 矢量图 颜色空间 图中字体 图中标签 坐标轴标签 多部分图中子图和表的标签 对本…

解决方案:Zotero实现参考文献中英文混排,将英文文献中的“等”转成“et al.”

Zotero 是一款非常实用且易于使用的参考文献管理工具&#xff0c;可帮助用户收集、整理和引用各种类型的文献&#xff0c;包括图书、期刊文章、网页等。在学术写作中起着重要作用。 但是其在中文世界中&#xff0c;运行起来偶尔会出现问题&#xff0c;这里记录一个问题及其解决…

好的产品经理都是这样绘制原型图的...

本片文章&#xff08;原型上篇&#xff09;重点内容&#xff1a; 清晰的视觉层次视觉流结构功能预见性信息的焦点即为视觉的焦点足够简单考虑到边界条件 首先&#xff0c;我们要明确原型图是画给谁看的&#xff0c;通常是以下几类人&#xff1a;开发、部门领导、UI设计师和测试…

好的产品经理都是这样绘制原型图的(下)...

前几天分享了上篇&#xff1a;好的产品经理都是这样绘制原型图的... 今天来分享下篇&#xff0c;本篇&#xff08;原型篇-下&#xff09;主要内容&#xff1a; 原型图标注&#xff0c;画开发看得懂的图同一个页面展示所有的交互状态页面跳转关系图&#xff08;不要做孤立的设计…

【通览一百个大模型】LaMDA(Google)

【通览一百个大模型】LaMDA&#xff08;Google&#xff09; 作者&#xff1a;王嘉宁&#xff0c;本文章内容为原创&#xff0c;仓库链接&#xff1a;https://github.com/wjn1996/LLMs-NLP-Algo 订阅专栏【大模型&NLP&算法】可获得博主多年积累的全部NLP、大模型和算法干…

生成式AI加入低代码,或将再次颠覆开发行业

研究表明&#xff0c;生成式AI模型的发展将会进一步降低使用低代码和无代码开发工具的门槛&#xff0c;并可能诞生一类全新的智能开发技术。 在帮助用户构建自己的软件应用程序方面&#xff0c;低代码和无代码平台已经发挥了至关重要的作用&#xff0c;这些用户很少具备或根本…

聊一下大学几年如何渡过

(点击即可收听) 随着高考志愿填报的结束&#xff0c;等待自己的就是录取&#xff0c;出分与录取是每个高考生最激动的时刻 如果被某个大学和专业录取了&#xff0c;那接下来就是好好去上大学了的 作为一个经过大学洗礼的自己&#xff0c;在这里有一些话想对即将步入大学的同学说…

这里有一份诚意满满的计算机专业推荐书单

随着高考陆续放榜&#xff0c;盼来成绩的考生与家长们又迎来另一个纠结的难题——志愿填报。确认自己的专业方向&#xff0c;不仅要综合自身兴趣与特长考虑&#xff0c;还需与未来的就业挂钩。 根据《2023高考志愿报告》&#xff0c;当前计算机科学与技术专业热度仍然排名第一位…

IntelliJ IDEA 中插件的安装过程

这里简单介绍一下 IntelliJ IDEA 中插件的安装过程 有两种方式&#xff1a; (1)在线安装 (2)本地安装/离线安装