用Vue.js开发一个电影App的前端界面

本文介绍如何使用Vue.js 2构建一个类似Netflix风格的电影流媒体Web界面。通过创建Vue实例,设置数据和路由,实现了电影介绍、页脚导航、电影组件以及收藏功能。文章还提供了代码示例和实际运行的链接。
摘要由CSDN通过智能技术生成

用Vue.js开发一个电影App的前端界面

我们要构建一个什么样的App?

我们大多数人使用在线流媒体服务(如Netflix)观看我们最喜欢的电影或者节目。这篇文章将重点介绍如何通过使用vue.js 2 建立一个类似风格的电影流媒体WEB交互界面(见上图)。

最终的产品可以去这里找:https://codepen.io/itslit/full/mvvjzr。

尽管Bulma将作为应用的CSS框架,但是本文将主要集中在Vue.js的使用和浏览CSS式样,如果你想跟着学,我设置了一个可以作为开始学习的地方,所有自定义组合,初始数据对象和必要的需要通过CDN引用的外部库(如Vue-router等),都可以从https://codepen.io/itslit/pen/qmzrev获得。

App的基本需求

让我们记下这些基本需求:

  1. 介绍(登录)屏幕

  2. 页脚要允许用户可以选择自己想要的电影

  3. 一个电影屏幕,显示电影的标题/描述和并且有“立即播放”的提示。

  4. 一个电影预告片屏幕,在电影播放时显示电影的预告片。

  5. 可以将电影添加到收藏夹中

我们将创建应用程序,让页脚随时出现,而首页、电影和电影预告片将共享相同的屏幕。

数据

为了简单起见,我们将从一个简单/可靠的数据对象(对象)开始,它将作为我们所有组件的主存储器。这个存储对象将拥有我们所需要的所有电影信息,并将集中在克里斯托弗·诺兰的令人敬畏的电影。下面是数据对象的一部分:

const movies = {

"dunkirk": {

"id": 'dunkirk'

"title": 'Dunkirk',

"subtitle": 'Dunkirk',

"description": 'Miraculous evacuation of Allied soldiers from Belgium, Britain, Canada, and France, who were cut off and surrounded by the German army from the beaches and harbor of Dunkirk, France, during the Battle of France in World War II.',

"largeImgSrc": `url('https://image.tmdb.org/t/p/w780/fudEG1VUWuOqleXv6NwCExK0VLy.jpg')`,

"smallImgSrc': 'https://image.tmdb.org/t/p/w185/fudEG1VUWuOqleXv6NwCExK0VLy.jpg',

"releaseDate": 'July 21 2017',

"duration": '1hr 46min',

"genre": 'Action, Drama, History',

"trailerPath": 'https://www.youtube.com/embed/F-eMt3SrfFU',

"favorite": false

},

"interstellar": {

...

},

"the-dark-knight-rises": {

...

},

"inception": {

...

},

"the-prestige": {

...

}

}

让我们开始构建App

既然我们已经创建了主要的存储对象并理解了我们的所有组件是如何布局的,我们就可以开始构建接口了。

让我们首先创建Vue实例。我们将把实例挂载到DOM元素app,并返回全局存储的movies,作为我们的HTML中访问的实例数据对象的一部分。

const rootApp = new Vue({

el: '#app',

data() {

return {

movieChoices: movies

}

}

})

我们现在可以开始处理每个独立的组件了。

页脚部分

让我们从列出数据存储中所有电影的固定页脚部分开始。

<div id="app">

<section class="hero is-primary is-medium">

<div class="hero-foot">

<div class="columns is-mobile">

<div v-for="movieChoice in movieChoices" class="column">

<li class="movie-choice">

<img :src="`${movieChoice.smallImgSrc}`" class="desktop"/>

<p class="mobile">{ { movieChoice.subtitle }}</p>

</li>

</div>

</div>

</div>

</section>

</div>

对已在上述粗体代码片段的部分:

  1. 我们用id="app"创建的DOM元素,在那里我们的Vue实例将被挂载。

  2. 我们使用的是原生的v-for指令从数据源movieChoices渲染列表。

  3. 在每一个movieChoice:

  • 我们将绑定一个图像的src到描述我们电影的smallImgSrc对象内的url(“desktop”)。

  • 我们用Mustache语法,数据绑定到movieChoice.subtitle作为手机屏幕文本显示内容。

随着所有CSS样式的渲染,我们的应用程序目前应该像这样:

用Vue.js开发一个电影App的前端界面

桌面页脚

用Vue.js开发一个电影App的前端界面

手机端页脚

电影介绍组件(和Vue-router)

我们创建了页脚,现在我们的目标是创建一个具有我们的App标题和描述的电影介绍组件。

我们已经提到了组件将共享相同的屏幕为即将上映的电影预告片和组件(即用户将能够在我们的APP中直接通过点击Intro -> Movie -> MovieComponent到达相应的链接)。

这是一个完美的用例添加vue-router库。vue-router是vue.js官方路由器,是允许组件深入的集成的可配置的路由器,还可以

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值