基于vant实现一个问卷调查
实现背景
最近学习《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实现一个问卷调查的更多相关文章
- Android消息传递之基于RxJava实现一个EventBus - RxBus
前言: 上篇文章学习了Android事件总线管理开源框架EventBus,EventBus的出现大大降低了开发成本以及开发难度,今天我们就利用目前大红大紫的RxJava来实现一下类似EventBus事 ...
- 基于SpringBoot开发一个Restful服务,实现增删改查功能
前言 在去年的时候,在各种渠道中略微的了解了SpringBoot,在开发web项目的时候是如何的方便.快捷.但是当时并没有认真的去学习下,毕竟感觉自己在Struts和SpringMVC都用得不太熟练. ...
- 基于线程开发一个FTP服务器
一,项目题目:基于线程开发一个FTP服务器 二,项目要求: 基本要求: 1.用户加密认证 2.允许同时多用户登录 3.每个用户有自己的家目录 ,且只能访问自己的家目录 4.对用户进行磁盘配 ...
- 基于 Express 搭建一个node项目 - 起步
一,如何基于 Express 搭建一个node项目 什么是Express 借用官方的介绍,Express是一个基于Node.js平台的极简.灵活的web应用开发框架,它提供了一系列强大的特性,帮助你创 ...
- 【Python】如何基于Python写一个TCP反向连接后门
首发安全客 如何基于Python写一个TCP反向连接后门 https://www.anquanke.com/post/id/92401 0x0 介绍 在Linux系统做未授权测试,我们须准备一个安全的 ...
- 基于 OpenResty 实现一个 WS 聊天室
基于 OpenResty 实现一个 WS 聊天室 WebSocket WebSocket 协议分析 WebSocket 协议解决了浏览器和服务器之间的全双工通信问题.在WebSocket出现之前,浏览 ...
- 如何基于Go搭建一个大数据平台
如何基于Go搭建一个大数据平台 - Go中国 - CSDN博客 https://blog.csdn.net/ra681t58cjxsgckj31/article/details/78333775 01 ...
- 基于PHP实现一个简单的在线聊天功能(轮询ajax )
基于PHP实现一个简单的在线聊天功能(轮询ajax ) 一.总结 1.用的轮询ajax 二.基于PHP实现一个简单的在线聊天功能 一直很想试着做一做这个有意思的功能,感觉复杂的不是数据交互和表结构,麻 ...
- 基于 React 实现一个 Transition 过渡动画组件
过渡动画使 UI 更富有表现力并且易于使用.如何使用 React 快速的实现一个 Transition 过渡动画组件? 基本实现 实现一个基础的 CSS 过渡动画组件,通过切换 CSS 样式实现简单的 ...
随机推荐
- 把自己的web项目发布到网页上
一.首先,登录自己的bce百度云,bce.baidu.com,建立一个自己的网站 点击左边的应用引擎BAE 点击BAE基础版的部署列表,刚开始是没有的,要添加部署 其中的选项只需要写域名(应用名称会和 ...
- Java的面向对象属性
定义类 定义类的过程就是定义类的属性的过程: 类的属性就是累的静态属性的简称,指类内包含的各项数据. 类的服务被称为成员函数或方法. 继承extends 通过定义继承方法,子类可以获得父类的所有属性和 ...
- 面向对象之封装 及@property装饰器使用
目录 封装 1.封装的定义 2.封装的目的: 3.封装的三种方式 4.封装的优点 5.访问限制(封装) @property 装饰器 属性property底层实现 封装 1.封装的定义 将复杂的丑陋的, ...
- python获取网络图片
方式1 使用urllib库 import urllib.request import os ,stat url = "https://cn.bing.com/th?id=OHR.Lidong ...
- HTML标签与属性
HTML中常用的一些标签和属性. 1.lang属性:搜索引擎 en:英文, zh:中文 2.meta:元数据 charset属性:字符集编码方式 3.h1~h6:标题 一级标题 ...
- Spring Controller RequestMapping
不同的Controller,可以标记相同的RequestMapping 但是精确到函数上时,不可以标记相同的RequestMapping构成完成相同的请求路径,如果标记,运行会报错,提示有相同的路径, ...
- ES6 Promise使用介绍
1.什么是Promise Promise 是异步编程的一种解决方案,比传统的解决方案——回调函数和事件——更合理和更强大. 这么说可能不够直观的理解,看下面的两个例子 // callback回调函数 ...
- 论文阅读:Forwarding Metamorphosis: Fast Programmable Match-Action Processing in Hardware for SDN
摘要: 在软件定义网络中,控制平面在物理上与转发平面分离,控制软件使用开放接口(例如OpenFlow)对转发平面(例如,交换机和路由器)进行编程. 本文旨在克服当前交换芯片和OpenFlow协议的两个 ...
- linux crontab 定时任务,任务命令单独linux执行正常,放定时任务就不执行了,解决办法 (原)
这是我crontab里面的内容 */30 * * * * ./usr/bin/wget -q -O sync_log.txt http://fly.dllm.cn/index.php/Home/In ...
- Spring-data-redis 第一天
1.Redis 这就不必哆嗦了,Redis 支持丰富的数据类型,String ,List,Sets ,Sorted Sets,Hashes,这就可以看出Java 操作Redis就要针对各种类型都有自己 ...