《vue3实战》运用splice方法实现电影评价系统的查看、修改、删除功能

这篇具有很好参考价值的文章主要介绍了《vue3实战》运用splice方法实现电影评价系统的查看、修改、删除功能。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

目录

         前言

         电影评价系统是什么?它能具有什么功能的体现?

一、splice方法的含义和作用

splice是什么?splice的作用体现在哪些方面?

         二、功能实现

以下是实现查看逻辑功能的代码

以下是实现修改逻辑功能的代码 

以下是实现删除逻辑功能的代码

三、最终效果图

电影评价系统电影信息页面的查看修改删除按钮展示图:

 查看框的展现图:

修改框的展现图:

删除功能的展现图:

四、部分代码块

查看框以及修改框代码如下:

总结


前言

电影评价系统是什么?它能具有什么功能的体现?

电影评价系统是一个用于用户评价电影的应用程序或平台。其功能通常包括:

  1. 用户注册和登录:用户可以注册账号并使用登录凭据进行登录,以便参与评价和访问其他功能。(《vue3实战》前面的博客中有写如何实现跳转登录的功能)

  2. 电影列表和搜索:系统应提供一个电影列表,供用户查看,并提供搜索功能,用户可以根据电影名称、类型、演员等条件来查找电影。

  3. 电影详情页:点击电影列表中的电影后,应显示电影的详细信息,例如电影名称、导演、演员、剧情简介、上映日期等。

  4. 评价和评论:用户可以对已看过的电影进行评价和撰写评论。评价可以是一个评分(如1-10分或星级评分)或者是一个文本评论。

  5. 推荐系统:根据用户的评价历史或行为,系统可以提供个性化的电影推荐,帮助用户发现他们可能感兴趣的新电影。

  6. 社交功能:用户可以跟踪其他用户,查看他们的评价和评论,并与其他用户进行交流和讨论。

  7. 电影信息的管理:系统应提供对电影信息的管理功能,包括添加新电影、编辑电影信息、删除电影等。

  8. 用户权限管理:系统可以针对不同用户角色(如管理员、普通用户)设置不同的权限和功能访问级别。

  9. 数据统计和分析:系统可以统计和分析用户评价和行为数据,生成电影排行榜、用户偏好分析等报告和图表。


一、splice方法的含义和作用

splice是什么?splice的作用体现在哪些方面?

含义:

在JavaScript中,"splice"是一个数组方法,用于在指定索引位置修改数组,删除或添加元素。它接受多个参数,包括起始索引、删除的元素数量以及可选的要添加的新元素。

作用:

  1. 删除元素:可以通过指定起始索引和删除元素数量来删除数组中的元素。这会直接修改原数组,并返回被删除的元素组成的新数组。

  2. 添加元素:除了删除元素外,"splice"方法还可以在指定索引位置添加新的元素。通过指定起始索引、删除元素数量为0,并传递要添加的元素作为参数,可以实现在指定位置插入新元素。

  3. 替换元素:通过指定起始索引和删除元素数量,并传递要添加的新元素作为参数,可以替换数组中的元素。

二、功能实现

以下是实现查看逻辑功能的代码

 《vue3实战》运用splice方法实现电影评价系统的查看、修改、删除功能,vue.js,前端,javascript

分析:

1.首先,在 query 方法中,接收一个 id 参数,表示要查看的电影的ID。

2.然后,通过 console.log(id) 打印出传入的 id 值,用于验证传参是否正确。

3.接着,将属性 closeA 的值设为 true,这是用于控制查看框的显示与隐藏的标志。

4.接下来,通过 for 循环遍历 this.courses 数组,以查找与传入的 id 值匹配的电影项。

5.在循环中使用条件判断 if (this.courses[i].id == id) 来判断当前电影项的ID是否与传入的 id 值匹配。如果匹配成功,则将当前电影项赋值给属性 this.queryMovies

6.这样,通过调用 query 方法并传入电影的ID,可以在控制台输出 id,并根据该 id 值查找匹配的电影项,并将其赋值给属性 this.queryMovies

7.当然,最后,具体的查看功能的实现需要结合代码的其他部分,需要在模板或页面上展示查看到的电影信息。

以下是实现修改逻辑功能的代码 

《vue3实战》运用splice方法实现电影评价系统的查看、修改、删除功能,vue.js,前端,javascript

《vue3实战》运用splice方法实现电影评价系统的查看、修改、删除功能,vue.js,前端,javascript

 分析:

1.首先,在 update 方法中,接收一个 id 参数,表示要修改的电影的ID。

2.然后,将属性 closeB 的值设为 true,用于控制修改框的显示与隐藏的标志。

3.接下来,通过 for 循环遍历 this.courses 数组,以查找与传入的 id 值匹配的电影项。

4.在循环中使用条件判断 if (this.courses[i].id == id) 来判断当前电影项的ID是否与传入的 id 值匹配。

5.如果匹配成功,则通过 JSON.parse(JSON.stringify(this.courses[i])) 将匹配到的电影项进行深拷贝,并将拷贝后的对象赋值给属性 this.updateMess。这样,this.updateMess 就保存了要修改的电影的详细信息。

6.接着,在 updateBtn 方法中,首先将 this.updateMess 对象进行深拷贝,赋值给 newsObj 对象。

7.然后,通过 for 循环遍历 this.courses 数组,以查找与 newsObj 对象具有相同ID值的电影项。

8.当找到匹配项时,使用 this.courses.splice(i, 1, newsObj) 将该电影项从 this.courses 中删除,并将 newsObj 插入到删除位置,实现了修改电影信息的功能。

9.接下来,调用了 queryUser() 方法,可能是用于重新查询电影信息并更新页面上的显示。

之后,将 this.updateMess 初始化为一个空对象,以清空修改信息。

10.最后,将属性 closeB 的值设为 false,用于控制修改框的显示与隐藏的标志。

这样,通过调用 update 方法并传入电影的ID,可以根据 id 值找到相应的电影项并将其详细信息赋值给 this.updateMess,再通过调用 updateBtn 方法,可以将修改后的电影信息应用到 this.courses 数组中,并进行相应的更新操作。

以下是实现删除逻辑功能的代码

《vue3实战》运用splice方法实现电影评价系统的查看、修改、删除功能,vue.js,前端,javascript

 分析:

1.首先,在 deleteUser 方法中,接收一个 id 参数,表示要删除的电影的ID。

2.接着,通过 console.log(id) 打印出传入的 id 值,可能是用于调试或验证传入的ID是否正确。

3.然后,通过 for 循环遍历 this.courses 数组,以查找与传入的 id 值匹配的电影项。

4.在循环中使用条件判断 if (this.courses[i].id == id) 来判断当前电影项的ID是否与传入的 id 值匹配。

5.如果匹配成功,则使用 this.courses.splice(i, 1)this.courses 数组中删除该电影项。这样,就实现了删除电影的功能。

6.最后,调用了 queryUser() 方法,可能是用于重新查询电影信息并更新页面上的显示。

7.这样,通过调用 deleteUser 方法并传入电影的ID,可以根据 id 值找到相应的电影项,并在 this.courses 数组中进行删除操作,实现了删除电影的功能。

三、最终效果图

电影评价系统电影信息页面的查看修改删除按钮展示图:

《vue3实战》运用splice方法实现电影评价系统的查看、修改、删除功能,vue.js,前端,javascript

 查看框的展现图:

《vue3实战》运用splice方法实现电影评价系统的查看、修改、删除功能,vue.js,前端,javascript

修改框的展现图:

《vue3实战》运用splice方法实现电影评价系统的查看、修改、删除功能,vue.js,前端,javascript

删除功能的展现图:

《vue3实战》运用splice方法实现电影评价系统的查看、修改、删除功能,vue.js,前端,javascript

四、部分代码块

查看框以及修改框代码如下:

 <div
            style="margin-top: -400px;margin-left: 200px;border-radius:10px;position: absolute;width: 800px ;height: 400px;background-color: darkgrey"
            v-show="closeA">
          <button @click="closeA=false">关闭</button>
          <table cellspacing="0" style="width: 100%;margin: auto">
            <tr>
              <td v-for="(movie,index) in movieObjOne" :key="index" style="text-align: center">
                {{ movie }}
              </td>
              <td v-for="(movie,index) in movieObjTwo" :key="index" style="text-align: center">
                {{ movie }}
              </td>
            </tr>
            <tr>
              <td v-for="(user,index) in queryMovies" :key="index">
                {{ user }}
              </td>
            </tr>
          </table>
        </div>
        <div
            style="margin-top: -400px;margin-left: 200px;border-radius:10px;position: absolute;width: 800px ;height: 400px;background-color: darkgrey"
            v-show="closeB">
          <button @click="closeB=false">关闭</button>
          <table cellspacing="0" style="width: 100%;margin: auto">
            <tr>
              <td v-for="(movie,index) in movieObjOne" :key="index" style="text-align: center">
                {{ movie }}
              </td>
            </tr>
            <tr>
              <td>
                <input placeholder="" v-model="updateMess.id">
              </td>
              <td>
                <input placeholder="" v-model="updateMess.username">
              </td>
              <td>
                <input placeholder="" v-model="updateMess.actor">
              </td>
              <td>
                <input placeholder="" v-model="updateMess.img">
              </td>
            </tr>
            <tr>
              <td v-for="(movie,index) in movieObjTwo" :key="index" style="text-align: center">
                {{ movie }}
              </td>
            </tr>
            <tr>
              <td>
                <input placeholder="" v-model="updateMess.number">
              </td>
              <td>
                <input placeholder="" v-model="updateMess.type">
              </td>
              <td>
                <input placeholder="" v-model="updateMess.content">
              </td>
            </tr>
            <tr>
              <td>
                <input type="button" value="确认修改" @click="updateBtn">
              </td>
            </tr>
          </table>
        </div>


总结

总的来说,"splice"方法是一个用于修改数组的强大方法,它可以删除、添加和替换数组中的元素。通过灵活使用不同的参数,可以实现对数组的灵活操作。

这篇博客展现了电影评价系统的查看、修改、删除功能,以后还会给大家展现更多关于电影评价系统的其他功能的实现,感谢大家多多支持!

 希望这篇博客能给各位朋友们带来帮助,最后请来过的朋友们留下你们宝贵的三连以及关注,感谢你们!文章来源地址https://www.toymoban.com/news/detail-653023.html

到了这里,关于《vue3实战》运用splice方法实现电影评价系统的查看、修改、删除功能的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 朴素贝叶斯算法实现 豆瓣Top250电影评价的情感分析与预测。​

    本文使用朴素贝叶斯算法实现 豆瓣Top250电影评价的情感分析与预测。 最近在学习自然语言正负面情感的处理问题,但是绝大部分能搜索到的实践都是Kggle上IMDB影评的情感分析。 所以在这里我就用最基础的朴素贝叶斯算法来对豆瓣的影评进行情感分析与预测。 在这里我参考了

    2024年02月10日
    浏览(27)
  • vue3中怎么运用组件

    目录 1.组件的作用 2.如何创建一个组件 3.如何使用一个组件 4.传递和接收组件属性 5.总结 Vue3是目前最流行的前端框架之一。Vue3基于组件化开发,也就是说,所有功能都是由编写简单的组件来实现的。本篇博客主要介绍Vue3中如何运用组件。 1.组件的作用 组件是Vue3中最重要的

    2023年04月15日
    浏览(23)
  • vue3中的hook公共函数封装及运用

    vue3 中的 hooks 就是函数的一种写法,就是将文件的一些单独功能的js代码进行抽离出来,放到单独的js文件中,或者说是一些可以复用的公共方法/功能 使用Vue3的组合API封装的可复用的功能函数 自定义hook的作用类似于vue2中的mixin技术 自定义Hook的优势: 很清楚复用功能代码的来

    2024年01月15日
    浏览(40)
  • Vue项目实战——实现一个任务清单【基于 Vue3.x 全家桶(简易版)】

    内容 参考链接 Vue2.x全家桶 Vue2.x 全家桶参考链接 Vue2.x项目(一) Vue2.x 实现一个任务清单 Vue2.x项目(二) Vue2.x 实现GitHub搜索案例 Vue3.x项目(三) Vue3.x 实现一个任务清单 1、前言 如果你对 vue3 的基础知识还很陌生,推荐先去学习一下 vue 基础 内容 参考链接 Vue2.x全家桶 Vu

    2024年02月02日
    浏览(43)
  • 【案例实战】NodeJS+Vue3+MySQL实现列表查询功能

    这篇文章,给大家带来一个列表查询的功能,从前端到后端的一个综合案例实战。 采用vue3作为前端开发,nodejs作为后端开发。 首先我们先来看一下完成的页面效果。点击分页,可以切换到上一页、下一页。搜索框可以进行模糊查询。 后端项目开发 好的,那么看完项目的演

    2024年02月06日
    浏览(31)
  • Vue3集成ThreeJS实现3D效果,threejs+Vite+Vue3+TypeScript 实战课程【一篇文章精通系列】

    这是一个使用Vue3,TypeScript,Vite和Three.js的项目。Vue3是一个流行的JavaScript框架,用于构建用户界面。TypeScript是一种静态类型的编程语言,它是JavaScript的超集,可以编译成纯JavaScript。Vite是一个由Evan You开发的新的前端构建工具,能够提供快速的冷启动和即时热更新。 Three.j

    2024年02月03日
    浏览(38)
  • Vue2 —— 项目实战(电影网首页的制作) 附源码

    文章目录 前言 一、 静态页面的实现以及拆分组件 二、 主页的实现 1. 导航栏的跳转 2. 榜单列表的呈现 三 、 相应源码 1. 首页HTML结构 2. 首页CSS样式 总结 关于静态页面的实现过程,在下文的源码中会有所呈现。以下重点阐述如何利用vue2实现本项目的过程。 关于拆分组件在

    2024年02月12日
    浏览(28)
  • vue3项目打开本地pdf文件实现方法

    效果图 引入pdf插件 注意一定要这个版本,不然会报错 key.split(...).at is not a function pdf页面封装 pdf存放目录 具体实现就这么多,欢迎来吐槽! 结语 一个人久了连喜欢上一个人都好难,不要轻易地拒绝学习新知,因为你所拒绝的不是别人,而是你自己的成长之路。

    2024年02月12日
    浏览(35)
  • Vue项目实战——【基于 Vue3.x + Vant UI】实现一个多功能记账本(登录注册页面,验证码)

    系列内容 参考链接 基于 Vue3.x + Vant UI 的多功能记账本(一) 项目演示,涉及知识点 基于 Vue3.x + Vant UI 的多功能记账本(二) 搭建开发环境 基于 Vue3.x + Vant UI 的多功能记账本(三) 开发导航栏及公共部分 项目演示 Vue3 + Vant UI_多功能记账本 1、登录注册页面 页面设计,页面

    2024年02月03日
    浏览(43)
  • Vue3实现组件级基类的几种方法

    Vue3的组件有三种代码组织方式 纯Option API (不含setup) option API + setup 纯 setup (即composition API) 对于这三种形式,设置基类的方法也略有不同。 vue3提供了 mixins和extends,但是尝试之后发现这两种方法只支持纯OptionAPI,设置的data会被识别,但是设置的setup里return 的 reactive,完

    2024年02月01日
    浏览(44)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包