微信小程序答题功能是怎样实现的

时间: 2023-07-13 22:10:41 浏览: 74
微信小程序中的答题功能可以通过以下步骤来实现: 1. 定义题目数据格式 首先,需要定义题目的数据格式,包括题目、选项、答案等信息。可以将题目数据存储在一个数组中,每个元素对应一道题目,例如: ```javascript [ { "question": "以下哪个不是 JavaScript 数据类型?", "options": ["number", "string", "array", "boolean"], "answer": 2 }, { "question": "以下哪个方法可以在数组的末尾添加一个元素?", "options": ["push()", "pop()", "shift()", "unshift()"], "answer": 0 }, // ... ] ``` 2. 显示题目界面 在小程序的 wxml 文件中,可以使用 `<view>` 和 `<button>` 等标签来显示题目和选项,并绑定相应的事件处理函数,例如: ```html <view class="question">{{currentQuestion.question}}</view> <view class="options"> <button wx:for="{{currentQuestion.options}}" wx:key="index" bind:tap="selectOption" data-index="{{index}}"> {{item}} </button> </view> ``` 3. 实现答题逻辑 在小程序的 js 文件中,需要实现答题逻辑。可以定义一个变量来记录当前题目的索引,以及一个变量来记录已答对的题目数。每次答题时,需要检查用户选择的选项是否正确,并更新已答对的题目数。当用户答完所有题目时,可以将结果存储到本地或者通过网络上传到服务器。 ```javascript Page({ data: { questions: [...], // 题目数组 currentQuestionIndex: 0, // 当前题目索引 correctCount: 0 // 已答对的题目数 }, selectOption(event) { const { index } = event.currentTarget.dataset; const { currentQuestionIndex, questions } = this.data; const currentQuestion = questions[currentQuestionIndex]; const isCorrect = index === currentQuestion.answer; if (isCorrect) { this.setData({ correctCount: this.data.correctCount + 1 }); } if (currentQuestionIndex === questions.length - 1) { // 答完所有题目,保存结果到本地或上传到服务器 } else { this.setData({ currentQuestionIndex: currentQuestionIndex + 1 }); } } }) ``` 需要注意的是,为了避免用户作弊,可以在服务器端随机生成题目,并将题目发送到客户端进行答题。同时,可以在客户端限制每个用户每天只能答题一定次数,或者限制答题时间等。

相关推荐

以下是一个简单的微信小程序答题页面的代码示例: html <view class="container"> <view class="question"> <text class="title">{{question.title}}</text> </view> <view class="options"> <block wx:for="{{question.options}}" wx:key="index"> <view class="option" bindtap="selectOption" data-index="{{index}}"> <text>{{option}}</text> </view> </block> </view> <button class="submit-btn" bindtap="submitAnswer">提交</button> <view class="feedback"> <text wx:if="{{showFeedback}}">{{feedback}}</text> </view> <button class="next-btn" bindtap="nextQuestion" wx:if="{{showNextButton}}">下一题</button> <view class="progress"> <text>进度:{{currentQuestionIndex + 1}}/{{questions.length}}</text> </view> </view> js // index.js Page({ data: { questions: [], // 题目数据 currentQuestionIndex: 0, // 当前题目索引 selectedOptionIndex: -1, // 用户选择的选项索引 showFeedback: false, // 是否显示答案反馈 feedback: '', // 答案反馈信息 showNextButton: false // 是否显示下一题按钮 }, onLoad: function () { // 获取题目数据并初始化页面 this.getQuestions(); }, getQuestions: function () { // 使用wx.request获取题目数据,将数据赋值给this.data.questions // 示例: wx.request({ url: 'https://example.com/questions', success: res => { this.setData({ questions: res.data }); }, fail: err => { console.error(err); } }); }, selectOption: function (e) { // 用户选择选项后的处理函数 const index = e.currentTarget.dataset.index; this.setData({ selectedOptionIndex: index }); }, submitAnswer: function () { // 提交答案的处理函数 const currentQuestion = this.data.questions[this.data.currentQuestionIndex]; const selectedOptionIndex = this.data.selectedOptionIndex; if (selectedOptionIndex === currentQuestion.correctIndex) { this.setData({ showFeedback: true, feedback: '回答正确!' }); } else { this.setData({ showFeedback: true, feedback: '回答错误!' }); } this.setData({ showNextButton: true }); }, nextQuestion: function () { // 切换到下一题的处理函数 if (this.data.currentQuestionIndex < this.data.questions.length - 1) { this.setData({ currentQuestionIndex: this.data.currentQuestionIndex + 1, selectedOptionIndex: -1, showFeedback: false, feedback: '', showNextButton: false }); } else { // 答题结束,跳转到结果页或其他页面 wx.navigateTo({ url: '/pages/result/result' }); } } }); 以上是一个简单的微信小程序答题页面的代码示例。你可以将代码保存在对应的文件中,并根据实际需求进行修改和扩展。需要注意的是,示例中的数据请求和页面跳转的具体实现可能需要根据你的实际情况进行调整。
开发微信小程序考试答题卡的功能包括用户授权认证、身份信息登记登录、身份信息查看、在线考试、管理员模拟考试列表、考试状态数据列表检索、选择要参加的考试类型、对多种类型的题目进行作答、查看已完成评分的考题、答题卡记录、微信服务通知等。\[1\]此外,还可以添加练习功能,包括顺序练习、随机练习、专项练习、题型练习等,以及答题模式和背题模式,实时查看答题卡,统计答题情况,记忆功能等。\[2\]开发者可以参考船长在船上的博客中关于前端开发的经验和技术分享,以获取更多关于开发微信小程序考试答题卡的相关信息。\[3\] #### 引用[.reference_title] - *1* *3* [微信小程序在线考试项目开发-注册登录功能](https://blog.csdn.net/SmartJunTao/article/details/126809683)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [微信小程序,基于考研考试等定做的小程序,有前后端完整源码和数据库,已开发上手](https://blog.csdn.net/weixin_51812604/article/details/127250424)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
### 回答1: 在线答题微信小程序源码.zip是一个用于开发在线答题微信小程序的源代码压缩文件。该压缩包中包含了实现在线答题功能所需的各种代码文件和资源文件。 在解压缩该文件后,可以看到一些主要的源代码文件,如主界面文件、题目列表文件、答题页面文件等。通过编辑这些源代码文件,可以自定义和修改微信小程序的界面、功能和逻辑。 此外,源码还包含了相关的资源文件,如图片、音频等,用于丰富小程序的用户体验。 该源码的设计初衷是方便开发者快速搭建一个在线答题的微信小程序,在线答题功能可以根据实际需求进行调整和增删。用户可以在小程序中选择相应的题目进行答题,并在答题过程中获得实时的反馈和评估。 通过该源码,开发者可以学习和掌握微信小程序的开发技术,并基于此进行二次开发,添加更多的功能和特性,以满足个性化需求。 总之,在线答题微信小程序源码.zip是一个提供在线答题功能的微信小程序的源代码压缩文件,提供了开发者进行二次开发和定制的基础。 ### 回答2: 在线答题微信小程序源码.zip 是一个包含在线答题功能的微信小程序的源代码压缩包。它提供了一个完整的在线答题系统,用户可以通过该小程序进行答题并获取答题结果。 这个小程序使用微信开发者工具进行开发,采用了小程序的框架和组件进行界面设计和功能实现。源码中包含了前端代码、后端代码和数据库模型等文件,开发者可以根据自己的需要进行定制和修改。 在小程序界面中,用户首先需要进行登录或注册操作,然后可以选择不同的答题类别和难度级别。答题过程中,小程序会根据用户的选项提供题目,并计算答题得分。用户可以在答题完成后查看自己的答题结果,并进行答题记录的管理。 这个小程序的源码还提供了其他一些功能,比如排行榜、答题历史记录等。开发者可以根据自己的需要进行功能扩展和修改。 总之,在线答题微信小程序源码.zip 提供了一个完整的在线答题系统的源代码,使用该源码可以快速搭建一个具有答题功能的微信小程序,并根据自己的需要进行定制和修改。
以下是一个简单的微信小程序在线答题的代码示例: 1. 首先需要在 wxml 文件中添加题目和选项的布局: html <view class="question">{{question}}</view> <view class="option" bindtap="checkAnswer" data-index="0">{{options[0]}}</view> <view class="option" bindtap="checkAnswer" data-index="1">{{options[1]}}</view> <view class="option" bindtap="checkAnswer" data-index="2">{{options[2]}}</view> <view class="option" bindtap="checkAnswer" data-index="3">{{options[3]}}</view> 2. 然后在 js 文件中定义题目和选项,并在页面加载时随机获取一道题目: javascript Page({ data: { question: '', options: [], correctAnswer: '', }, onLoad: function() { this.getQuestion(); }, getQuestion: function() { // 从题库中获取题目和选项 var questionData = [ { question: '以下哪个不是JavaScript的数据类型?', options: ['string', 'number', 'boolean', 'array'], correctAnswer: 3, }, // 更多题目... ]; // 随机获取一道题目 var index = Math.floor(Math.random() * questionData.length); this.setData({ question: questionData[index].question, options: questionData[index].options, correctAnswer: questionData[index].correctAnswer, }); }, checkAnswer: function(e) { // 获取用户选择的答案 var userAnswer = e.currentTarget.dataset.index; // 判断用户答案是否正确 if (userAnswer == this.data.correctAnswer) { wx.showToast({ title: '回答正确!', icon: 'success', duration: 2000, }); } else { wx.showToast({ title: '回答错误!', icon: 'none', duration: 2000, }); } // 获取下一道题目 this.getQuestion(); }, }); 3. 最后在 wxss 文件中添加样式: css .question { font-size: 24rpx; margin-top: 40rpx; margin-bottom: 20rpx; } .option { font-size: 20rpx; margin-bottom: 20rpx; padding: 20rpx; border: 1rpx solid #ccc; border-radius: 10rpx; cursor: pointer; } .option:hover { background-color: #f5f5f5; } 这样就可以实现一个简单的微信小程序在线答题功能了。当用户选择答案后,会显示回答结果并自动获取下一道题目。需要注意题目和选项的数据可以根据实际需求进行修改。
### 回答1: 这个功能可以通过编写小程序的代码实现。具体来说,可以在小程序中设置一个题目列表,每个题目包含题目内容、选项和正确答案等信息。当用户选择一个选项后,可以通过代码判断用户选择的答案是否正确,并自动切换到下一题。可以使用小程序框架提供的组件和API来实现这个功能。 ### 回答2: 微信小程序答题是目前非常流行的一种娱乐方式,在小程序中,玩家可以通过选择答案的方式来完成一个有趣的知识测试,并在测试结束后查看自己的得分情况。此类小程序在玩法上与之前的APP或网页版答题游戏相似,但是却更加便捷,无需下载和注册。 针对微信小程序答题中选择答案后自动切换下一题的机制,其实是一种非常普遍的设计方式。在设计小程序的建造过程中,开发者可以设置一个调用的事件或函数,当玩家选择答案之后,该事件或函数会被触发,从而实现自动切换至下一题的效果。具体实现方法可以有多种方式,比较通用的是将所有问题的数据源存储在一个数组中,然后利用JavaScript编写函数实现题目的遍历和展示,当玩家选择答案时,程序自动将索引号加1,并切换至下一题目。 除此之外,微信小程序答题还常常会加入一些扩展玩法,如计时、排行榜等,增强玩家参与度和趣味性。这些扩展性的开发,需要在小程序开发中加入额外的模块或配置,从而实现各种功能。此外,在微信小程序答题应用的设计中,还要注意UI界面简洁流畅、答案选项设计合理等方面,以提高用户体验。 总之,在微信小程序答题的设计中,自动切换下一题是必不可少的一个关键点,这也是小程序玩家喜爱在微信小程序上玩答题游戏的原因之一。同时也期望开发者在答题小程序中加入更多有趣扩展玩法,从而为用户带来更为完整的答题体验。 ### 回答3: 微信小程序答题游戏是一种互动性强的社交娱乐活动,相比传统的答题方式,微信小程序答题游戏更加便捷、互动性更强。在微信小程序答题游戏中,选择答案后系统会自动切换下一题,对于参与者来说,无需手动翻页,操作方便快捷。 对于开发者来说,微信小程序答题游戏的开发难度不高,开发成本也比较低。开发者可以根据自己的理解和要求,设计出有趣的、创新的答题游戏。同时,其便捷的互动性,也可以吸引更多的用户涌入游戏中,进一步提升了社交化游戏的体验感。在游戏中,玩家可以利用答题游戏来补充自己的专业知识,并在和其他玩家的互动中提高自己的游戏技巧。 微信小程序答题游戏将互动性、社交化、便捷性等方面集于一身,不仅在营销推广方面有着广泛的使用,同时也可以作为企业在内部培训中使用,增强员工的知识水平和团队合作能力,实现企业的发展目标。总之,微信小程序答题游戏作为一种娱乐、教育、推广的有机结合,在不断的发展中,将更加贴近用户需求,成为移动互联网生态中景气的一道风景线。
微信小程序开发可以使用微信小程序开发工具。微信小程序开发工具是微信官方提供的一款集成开发环境,可以帮助开发者进行小程序的开发、调试和发布。在开发小程序时,需要使用到的技术包括jdk版本1.8及以上、IDE工具如Eclipse或者IDEA、数据库如MySQL 5.7、编程语言Java、Tomcat 8.0及以上、Java框架SSM、Maven 3.6.1等。同时,还需要掌握HTML、CSS、Vue等技术。\[1\] 如果想要使用更加方便的开发框架,可以考虑使用weUi、mpVue或WePY。weUi是微信官方团队为微信web开发量身打造的一个UI样式库,可以使小程序中的组件风格与微信相似,提升用户体验。mpVue是在Vue.js基础上增加了开发微信小程序能力的框架,而WePY则是参考了Vue.js等现有框架的语法和功能特性,对原生小程序的开发模式进行了再次封装,更贴近于MVVM框架,支持组件开发和单文件模式,开发更加方便。\[2\] 微信小程序相比于原生app和webapp有一些区别。微信小程序适合开发一些业务逻辑简单、低频次使用、对性能要求不高的应用。原生app需要开发两个版本,开发成本较高。而基于HTML5开发的webapp虽然解决了跨平台问题,但性能和用户体验可能不如原生app和微信小程序。\[3\] #### 引用[.reference_title] - *1* [【毕业设计】基于微信小程序的在线答题考试系统](https://blog.csdn.net/qq_15801219/article/details/127580848)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [期末考试的一些整理 移动开发微信小程序](https://blog.csdn.net/m0_57549184/article/details/122157603)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
### 回答1: 微信小程序Vant Weapp是一款基于Vant UI组件库开发的小程序框架,可以快速搭建小型应用程序。调查问卷demo是Vant Weapp的一个示例项目,用于展示如何利用Vant Weapp的组件来实现一个简单的调查问卷功能。 这个demo包含了问题列表、单选题和多选题、文本输入框、提交按钮等常见的调查问卷元素。用户可以根据自己的需要来编辑问题和选项,并选择问题的类型。在填写完问卷后,用户可以点击提交按钮将问卷内容发送到后台服务器进行数据处理。 Vant Weapp的组件库中提供了丰富的UI组件,包括按钮、表单、弹窗、轮播图等等,这些组件都可以在调查问卷demo中找到相应的运用。开发者可以根据自己的需求来选择和定制这些UI组件,实现个性化的问卷设计。 Vant Weapp还提供了丰富的API和文档,方便开发者进行定制化开发。开发者可以根据自己的业务需求,对问卷demo进行二次开发,添加更多的功能和交互,以满足用户的不同需求。同时,Vant Weapp也对小程序的性能做了优化,保证了用户的流畅体验。 总之,微信小程序Vant Weapp调查问卷demo是一个简单而实用的小程序示例项目,结合了Vant Weapp的UI组件和功能,可以快速搭建一个调查问卷系统,并满足个性化的需求。开发者可以通过定制化开发,进一步优化问卷的功能和用户体验。 ### 回答2: 微信小程序是一种在微信内部运行的应用程序,而Vant Weapp是一款基于微信小程序的 UI 组件库。调查问卷demo是Vant Weapp提供的一个示例应用,用于展示如何使用Vant Weapp构建一个调查问卷的小程序。 调查问卷demo通过Vant Weapp提供的丰富组件和模板,实现了一个简单而功能强大的调查问卷应用。用户可以通过小程序直接访问该demo,进而参与问卷调查。 在这个demo中,用户可以看到问卷的标题、问题和选项,并可以根据自己的选择进行答题。同时,该demo还提供了一些基本的问卷统计功能,比如展示各个问题的答题人数和选择比例。 该调查问卷demo的实现主要分为以下几个步骤: 1. 导入Vant Weapp组件库,并进行相关配置。 2. 创建问卷页面,并使用Vant Weapp提供的组件来布局和展示问卷内容。 3. 根据问卷模板,在页面中动态渲染问卷的标题、问题和选项等数据。 4. 实现用户答题的交互逻辑,比如监听用户选择的事件,并记录用户的选择。 5. 根据用户的答题情况,进行相关的统计和展示,比如展示选择比例和回答人数等。 通过参考这个调查问卷demo,开发者可以学习到如何在微信小程序中使用Vant Weapp来构建界面,并实现一些基本的交互和数据处理功能。同时,开发者也可以根据自己的需求对该demo进行修改和扩展,以满足实际的调查问卷应用场景的需求。 ### 回答3: 微信小程序vant weapp调查问卷demo是一个基于微信小程序开发框架vant和weapp的调查问卷示例程序。这个demo主要实现了一个简单的调查问卷功能,可以帮助用户快速创建、发布和统计问卷。 首先,在小程序的首页上,用户可以浏览到已发布的问卷列表。用户可以点击进入问卷详情页面,查看问卷的具体内容和选项。 在问卷详情页面,用户可以选择相应的选项,并提交答卷。提交后,用户可以查看自己的答卷结果,并可以查看所有答卷的统计结果。统计结果以图表的形式展示,方便用户直观地了解问卷结果。 在创建问卷页面,用户可以编辑问卷的标题、问题和选项。用户可以自定义问卷的类型,包括单选、多选等。还可以设置问卷的截止日期,以及是否匿名发布。 在后台管理页面,管理员可以管理发布的问卷,包括编辑、删除问卷。管理员还可以查看问卷的答卷统计结果,以及导出答卷数据。 使用vant和weapp开发这个调查问卷demo的好处是,vant提供了丰富的组件和样式,可以帮助开发者快速构建小程序的UI界面。weapp是微信小程序的开发框架,具有方便、高效的特点,使用起来非常方便。 总的来说,微信小程序vant weapp调查问卷demo是一个功能简单但实用的问卷调查程序,通过这个demo,用户可以方便地创建、发布和统计问卷,帮助用户快速了解用户的需求和意见。同时,vant和weapp的使用也为开发者提供了便捷的开发方式,帮助开发者快速构建小程序。

最新推荐

微信小程序实现时间进度条功能

主要为大家详细介绍了微信小程序实现时间进度条功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

DAC简介及参考电路PPT学习教案.pptx

DAC简介及参考电路PPT学习教案.pptx

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire

OceanBase数据库简介及原理解析

# 1. OceanBase数据库概述 ## 1.1 OceanBase数据库的发展历程 OceanBase数据库是由阿里巴巴集团自主研发的一款分布式关系型数据库系统,起源于阿里集团的业务需求和技术挑战。自2010年开始研发,经过多年的迭代和优化,OceanBase已经成为阿里巴巴集团重要的核心数据库产品之一。在实际的业务场景中,OceanBase已经被广泛应用于金融、电商、物流等各个领域。 ## 1.2 OceanBase数据库的特点和优势 OceanBase数据库具有以下特点和优势: - **分布式架构**:OceanBase采用多副本分布式架构,可以实现高可用和数据容灾。 -

python的pandas读取excel怎么将excel表里的列从1开始而不是0

在 Pandas 中,数据框的列默认从0开始编号,但我们可以通过自定义函数来进行数据列的转换。可以先将读取的数据框列的第一个值设为1,然后对后续列进行递增处理。 以下是示例代码: ```python import pandas as pd # 读取 Excel 文件 df = pd.read_excel('your_excel_file.xlsx') # 定义函数将列从1开始 def reset_column(x): return str(int(x) + 1) # 应用函数到所有列名 df = df.rename(columns=reset_column) # 打印数据框

第三章薪酬水平、薪酬系统的运行与控制.pptx

第三章薪酬水平、薪酬系统的运行与控制.pptx

"互动学习:行动中的多样性与论文攻读经历"

多样性她- 事实上SCI NCES你的时间表ECOLEDO C Tora SC和NCESPOUR l’Ingén学习互动,互动学习以行动为中心的强化学习学会互动,互动学习,以行动为中心的强化学习计算机科学博士论文于2021年9月28日在Villeneuve d'Asq公开支持马修·瑟林评审团主席法布里斯·勒菲弗尔阿维尼翁大学教授论文指导奥利维尔·皮耶昆谷歌研究教授:智囊团论文联合主任菲利普·普雷教授,大学。里尔/CRISTAL/因里亚报告员奥利维耶·西格德索邦大学报告员卢多维奇·德诺耶教授,Facebook /索邦大学审查员越南圣迈IMT Atlantic高级讲师邀请弗洛里安·斯特鲁布博士,Deepmind对于那些及时看到自己错误的人...3谢谢你首先,我要感谢我的两位博士生导师Olivier和Philippe。奥利维尔,"站在巨人的肩膀上"这句话对你来说完全有意义了。从科学上讲,你知道在这篇论文的(许多)错误中,你是我可以依

理解MVC架构:Laravel框架的核心设计

# 1. 第1章 项目立项与概述 ## 1.1 动机 随着互联网的快速发展,Web应用的开发需求不断增加。为了提高开发效率、代码可维护性和团队协作效率,我们决定采用MVC架构来设计我们的Web应用。 ## 1.2 服务器状态 我们的服务器环境采用了LAMP(Linux + Apache + MySQL + PHP)架构,满足了我们Web应用开发的基本需求,但为了更好地支持MVC架构,我们将对服务器进行适当的配置和优化。 ## 1.3 项目立项 经过团队讨论和决定,决定采用Laravel框架来开发我们的Web应用,基于MVC架构进行设计和开发,为此做出了项目立项。 ## 1.4 项目概况

如何将HDFS上的文件读入到Hbase,用java

要将HDFS上的文件读入到HBase,可以使用Java编写MapReduce程序实现,以下是实现步骤: 1. 首先需要创建一个HBase表,可使用HBase Shell或Java API创建; 2. 编写MapReduce程序,其中Map阶段读取HDFS上的文件,将数据转换成Put对象,然后将Put对象写入到HBase表中; 3. 在MapReduce程序中设置HBase表名、列族名、列名等参数; 4. 在程序运行前,需要将HBase相关的jar包和配置文件加入到classpath中; 5. 最后提交MapReduce任务运行即可。 以下是示例代码: ``` Configuration

酒店餐饮部工作程序及标准(某酒店).doc

餐饮