实现背景

最近学习《vue实战》,第二篇进阶篇有一个练习

刚好最近在研究vue移动端框架vant

两者结合,实现这么个小项目

实现代码

新建 vue单文件 L0529L.vue

<template>
<div class="dom">
<div class="tmnr">{{showtm+1}}. {{timu[showtm]['tmcontent']}}</div>
<component0529
:info="ziInfo"
:showtm="showtm"
@chooseRadio="changeAnswer"
@chooseCheckbox="changeAnswer"
@chooseInput="changeAnswer"
></component0529>
<div class="buttondom">
<van-button type="primary" v-show="showtm>0" @click="shangtm" :disabled="showtm===0">上一题</van-button>
<van-button
type="primary"
v-show="showtm<timu.length-1"
@click="nexttm"
:disabled="nextdisable"
>下一题</van-button>
<van-button type="warning" @click="chongzhi">重置</van-button>
</div>
</div>
</template> <script>
import component0529 from "./views/component0529"; export default {
name: "",
data() {
return {
showtm: 0,
timu: [
{
id: 1,
type: "radio",
tmcontent: "题目内容1-单选",
xx: [
{ id: "A", nr: "选项A-单选" },
{ id: "B", nr: "选项B-单选" },
{ id: "C", nr: "选项C-单选" }
],
cannext: false,
answer: ""
},
{
id: 2,
type: "checkbox",
tmcontent: "题目内容2-复选",
xx: [
{ id: "A", nr: "选项A", ischeck: false },
{ id: "B", nr: "选项B", ischeck: false },
{ id: "C", nr: "选项C", ischeck: false },
{ id: "D", nr: "选项D", ischeck: false }
],
cannext: false,
answer: []
},
{
id: 3,
type: "input",
tmcontent: "题目内容3-问答",
cannext: false,
answer: ""
}
]
};
},
computed: {
ziInfo() {
return this.timu[this.showtm];
},
nextdisable() {
var a = false;
if (this.showtm == this.timu.length - 1) a = true;
var t = this.timu[this.showtm]["type"];
switch (t) {
case "radio":
if (this.timu[this.showtm]["answer"] == "") a = true;
break;
case "checkbox":
if (
this.timu[this.showtm]["answer"].length != 2 &&
this.timu[this.showtm]["answer"].length != 3
)
a = true;
break;
case "input":
var c = this.timu[this.showtm]["answer"];
if (c.length < 100) a = true;
break;
}
return a;
}
},
components: {
component0529
},
methods: {
nexttm() {
this.showtm++;
},
shangtm() {
this.showtm--;
},
chongzhi() {
if (this.timu[this.showtm]["type"] == "checkbox") {
this.timu[this.showtm]["answer"].length = 0;
for (var i = 0; i < this.timu[this.showtm]["xx"].length; i++) {
this.timu[this.showtm]["xx"][i]["ischeck"] = false;
}
} else {
this.timu[this.showtm]["answer"] = "";
}
},
changeAnswer(ans) {
this.timu[this.showtm]["answer"] = ans;
}
}
};
</script> <style scoped>
.dom{
padding: 14px;
}
.tmnr{
margin: 10px 0px;
text-align: left;
}
.buttondom {
position: absolute;
bottom: 10px;
text-align: center;
width: 100%;
}
</style>

  引入组件 component0529.vue 代码:

<template>
<ul>
<li v-if="info.type==='checkbox'">
<van-checkbox
v-for="infoa in childInfo.xx"
v-model="infoa.ischeck"
@change="changeCheckbox"
>{{infoa.nr}}</van-checkbox>
</li>
<li v-else-if="info.type==='radio'">
<van-radio-group v-model="childInfo.answer" @change="changeRadio">
<van-radio v-for="infoa in childInfo.xx" :name="infoa.id">{{infoa.nr}}</van-radio>
</van-radio-group>
</li>
<li v-else-if="info.type==='input'">
<van-cell-group>
<van-field
v-model="childInfo.answer"
type="textarea"
placeholder="请输入不少于100字"
rows='1'
autosize
border="true"
/>
</van-cell-group>
</li>
</ul>
</template> <script>
export default {
props: ["info", "showtm"],
data() {
return {};
},
computed: {
childInfo() {
var an = this.info["answer"],
type = this.info["type"]; if (type == "checkbox") {
for (var i = 0; i < this.info.xx.length; i++) {
var x = this.info.xx[i];
if (an.join(",").indexOf(x.id) > -1) x.ischeck = true;
}
} return this.info;
}
},
methods: {
changeRadio() {
var a = this.childInfo.answer;
this.$emit("chooseRadio", a);
},
changeCheckbox() {
var a = [];
for (var i = 0; i < this.childInfo.xx.length; i++) {
if (this.childInfo.xx[i]["ischeck"]) a.push(this.childInfo.xx[i]["id"]);
} this.$emit("chooseCheckbox", a);
},
changeInput() {
this.$emit("chooseInput", this.childInfo.answer);
}
},
components: {}
};
</script> <style scoped>
ul li .van-radio,
.van-checkbox {
margin: 16px 0px;
}
</style>

  

实现页面展示

 解释逻辑

1.在L0529L.vue 定义好相关问卷题目,设计好题目类型,内容,选项,选择或者输入的答案等

2.定义一个当前题目id==showtm,用这个参数决定当前显示的是哪道题。

3、将题目传递给子组件component0529.vue,在这里面处理显示选项信息或者输入框

4、子组件信息操作选择完成或者输入了相关信息,修改对应父组件中问题的答案

5、刚接触vue,逻辑方面有些冗余啰嗦,以后有更好的实现想法再进行修改

基于vant实现一个问卷调查的更多相关文章

  1. Android消息传递之基于RxJava实现一个EventBus - RxBus

    前言: 上篇文章学习了Android事件总线管理开源框架EventBus,EventBus的出现大大降低了开发成本以及开发难度,今天我们就利用目前大红大紫的RxJava来实现一下类似EventBus事 ...

  2. 基于SpringBoot开发一个Restful服务,实现增删改查功能

    前言 在去年的时候,在各种渠道中略微的了解了SpringBoot,在开发web项目的时候是如何的方便.快捷.但是当时并没有认真的去学习下,毕竟感觉自己在Struts和SpringMVC都用得不太熟练. ...

  3. 基于线程开发一个FTP服务器

    一,项目题目:基于线程开发一个FTP服务器 二,项目要求: 基本要求: 1.用户加密认证   2.允许同时多用户登录   3.每个用户有自己的家目录 ,且只能访问自己的家目录   4.对用户进行磁盘配 ...

  4. 基于 Express 搭建一个node项目 - 起步

    一,如何基于 Express 搭建一个node项目 什么是Express 借用官方的介绍,Express是一个基于Node.js平台的极简.灵活的web应用开发框架,它提供了一系列强大的特性,帮助你创 ...

  5. 【Python】如何基于Python写一个TCP反向连接后门

    首发安全客 如何基于Python写一个TCP反向连接后门 https://www.anquanke.com/post/id/92401 0x0 介绍 在Linux系统做未授权测试,我们须准备一个安全的 ...

  6. 基于 OpenResty 实现一个 WS 聊天室

    基于 OpenResty 实现一个 WS 聊天室 WebSocket WebSocket 协议分析 WebSocket 协议解决了浏览器和服务器之间的全双工通信问题.在WebSocket出现之前,浏览 ...

  7. 如何基于Go搭建一个大数据平台

    如何基于Go搭建一个大数据平台 - Go中国 - CSDN博客 https://blog.csdn.net/ra681t58cjxsgckj31/article/details/78333775 01 ...

  8. 基于PHP实现一个简单的在线聊天功能(轮询ajax )

    基于PHP实现一个简单的在线聊天功能(轮询ajax ) 一.总结 1.用的轮询ajax 二.基于PHP实现一个简单的在线聊天功能 一直很想试着做一做这个有意思的功能,感觉复杂的不是数据交互和表结构,麻 ...

  9. 基于 React 实现一个 Transition 过渡动画组件

    过渡动画使 UI 更富有表现力并且易于使用.如何使用 React 快速的实现一个 Transition 过渡动画组件? 基本实现 实现一个基础的 CSS 过渡动画组件,通过切换 CSS 样式实现简单的 ...

随机推荐

  1. 基于TCP的客户端、服务器端socket编程

    一.实验目的 理解tcp传输客户端服务器端通信流程 二.实验平台 MAC OS 三.实验内容 编写TCP服务器套接字程序,程序运行时服务器等待客户的连接,一旦连接成功,则显示客户的IP地址.端口号,并 ...

  2. 【LOJ#536】「LibreOJ Round #6」花札

    题目链接 题目描述 「UniversalNO」的规则如下:每张牌有一种颜色和一个点数.两个人轮流出牌,由 Alice 先手,最开始牌堆为空,出的人可以出任意牌(放到牌堆顶),之后出的牌必须和当时牌堆顶 ...

  3. xpath的编写规则

    xpath的编写规则是// 表示从任意一级开始,或间隔任意级.换句话说中间就是可以隔很多层/ 从根目录开始,或从上一层的次层开始,就是需要跟上一层是上下级关系@id=aaa,id=aaa的元素,和元素 ...

  4. [CF1105E] Helping Hiaset

    问题描述 你在某社交网站上面注册了一个新账号,这个账号有\(n(n\leq 10^5)\)次记录.要么就是你更改过一次ID,要么就是一个ID为\(s(|s|\leq 40)\)的朋友访问过你的空间. ...

  5. python基础语法-Ⅲ

    Python注释 python中单行注释采用 # 开头. 实例 输出结果: 注释可以在语句或表达式行末: python 中多行注释使用三个单引号(''')或三个双引号(""&quo ...

  6. Redis常见面试问题及答案

    大量key在同一时间过期,注意什么? 如果过期时间过于集中,会导致Redis可能会出现短暂的卡顿现象.严重的话会出现缓存雪崩,一般需要在时间上加一个随机值, 使用过期时间分散一些. Redis分布式锁 ...

  7. jquery target属性 语法

    jquery target属性 语法 作用:target 属性规定哪个 DOM 元素触发了该事件.大理石平台精度等级 语法:event.targe 参数: 参数 描述 event     必需.规定需 ...

  8. HDU 3480 Division DP斜率优化

    解题思路 第一步显然是将原数组排序嘛--然后分成一些不相交的子集,这样显然最小.重点是怎么分. 首先,我们写出一个最暴力的\(DP\): 我们令$F[ i ][ j ] $ 为到第\(i\)位,分成\ ...

  9. Compress Words

    E. Compress Words 直接套 KMP 即可(那为什么打 cf 的时候没有想到...),求出后一个单词(word)的前缀数组,然后从前面已得的字符串的末尾 - word. length ( ...

  10. MySQ彻底删除与安装配置

    彻底删除 1.查看 MySQL 安装了哪些东西 rpm -qa |grep -i mysql 2.卸载 -.el7.x86_64 -.el7.x86_64 .noarch -.el7.x86_64 - ...