vue+tailwind实现列表详情页分屏显示交互效果
代码语言:html
所属分类:布局界面
代码描述:vue+tailwind实现列表详情页分屏显示交互效果
下面为部分代码预览,完整代码请点击下载或在bfwstudio webide中打开
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <link type="text/css" rel="stylesheet" href="http://repo.bfw.wiki/bfwrepo/css/tailwind.min.css"> <link rel='stylesheet' href='https://unpkg.com/ionicons@4.5.5/dist/css/ionicons.min.css'> <style> input, textarea, button:focus, select { outline: none; resize: none; } input::placeholder, textarea::placeholder { color: #A0AEC0; opacity: 1; } select { -webkit-appearance: none; background: center right 12px / 12px url() no-repeat; } .group:hover .group-hover-block { display: block !important; } </style> </head> <body translate="no"> <div id="app" class="text-black antialiased"> <div class="flex w-screen" style="max-width: 100vw;"> <div class="h-screen flex flex-col flex-1 overflow-scroll" v-if="!doShowFullScreenActors"> <div class="h-10 flex px-3 items-center"> <div class="w-3 h-3 mr-1 bg-gray-300 rounded-full"></div> <div class="w-3 h-3 mr-1 bg-gray-300 rounded-full"></div> <div class="w-3 h-3 mr-2 bg-gray-300 rounded-full"></div> <div class="mx-1 px-1 w-5 h-5 bg-gray-300 rounded"></div> <button class="px-2 ion-md-arrow-back text-xl rounded text-gray-400"></button> <button class="px-2 ion-md-arrow-forward text-xl rounded text-gray-400"></button> <div class="mx-1 px-1 w-12 h-3 bg-gray-300 rounded"></div> <div class="text-gray-400">/</div> <div class="mx-1 px-1 w-12 h-3 bg-gray-300 rounded"></div> <div class="flex-1"></div> <div class="mx-1 px-1 w-12 h-3 bg-gray-300 rounded"></div> <div class="mx-1 px-1 w-12 h-3 bg-gray-300 rounded"></div> <div class="mx-1 px-1 w-12 h-3 bg-gray-300 rounded"></div> <div class="mx-1 px-1 w-5 h-5 bg-gray-300 rounded"></div> </div> <div class="flex-1 flex"> <div class="flex-1 px-8" :class="{'px-16': !doShowProjectDetails && !doShowActorDetails}"> <div class="h-16"></div> <div class="text-3xl font-bold">The Camera-Stylo</div> <div> <div class="flex items-center border-b py-2 mt-3"> <div class="text-lg font-semibold mr-2">Films</div> <div class="mx-1 px-1 w-12 h-3 bg-gray-300 rounded"></div> <div class="flex-1"></div> <div class="mx-1 px-1 w-12 h-3 bg-gray-300 rounded"></div> <div class="mx-1 px-1 w-5 h-5 bg-gray-300 rounded"></div> <button class="ion-ios-more text-xl text-gray-600 mx-1 px-2 hover:bg-gray-200 rounded" @click="doShowMoreMenu = true"></button> <div class="relative"> <div class="fixed top-0 left-0 h-screen w-screen bg-white" style="opacity: 0.01" v-if="doShowMoreMenu" @click="doShowMoreMenu = false"></div> <div v-if="doShowMoreMenu" class="absolute bg-white w-48 shadow rounded text-sm" style="right: -12px; top: -32px;"> <div class="mx-3 px-1 my-3 w-24 h-3 bg-gray-300 rounded"></div> <div class="mx-3 px-1 my-3 w-16 h-3 bg-gray-300 rounded"></div> <div class="mx-3 px-1 my-3 w-16 h-3 bg-gray-300 rounded"></div> <div class="mx-3 px-1 my-3 w-24 h-3 bg-gray-300 rounded"></div> <div class="flex items-center px-3 py-1 border-t border-b hover:bg-gray-200 cursor-pointer" @click="isInSidebarMode = !isInSidebarMode"> <div>Split-screen</div> <div class="flex-1"></div> <div class="w-8 h-5 bg-gray-400 rounded-full flex" :class="{'justify-end bg-blue-500': isInSidebarMode}"> <div class="h-5 w-5 rounded-full bg-white border-2 border-gray-400" :class="{'border-blue-500': isInSidebarMode}"></div> </div> </div> <div class="mx-3 px-1 my-3 w-16 h-3 bg-gray-300 rounded"></div> <div class="mx-3 px-1 my-3 w-24 h-3 bg-gray-300 rounded"></div> </div> </div> <div class="mx-1 px-1 w-12 h-6 bg-blue-400 rounded"></div> </div> <div class="flex border-b text-sm"> <div class="flex-1 px-2 border-r py-3"> <div class="w-16 h-2 bg-gray-300 rounded"></div> </div> <div class="flex-1 px-2 border-r py-3"> <div class="w-16 h-2 bg-gray-300 rounded"></div> </div> <div class="flex-1 px-2 py-3"> <div class="w-16 h-2 bg-gray-300 rounded"></div> </div> <div class="w-4"></div> </div> <div v-for="project, i in projects" class="flex border-b text-sm group items-center" :class="{'hover:bg-gray-200 cursor-pointer': isInSidebarMode, 'bg-gray-200': selectedProject === i}" @click="rowPressed(i)"> <div class="flex-1 px-2 border-r py-2 flex item-center group "> <div class="flex-1">{{project.name}}</div> <button class="uppercase text-xs border rounded px-1 hidden group-hover-block" @click="openPressed(i)" v-if="!isInSidebarMode">Open</button> </div> <div class="flex-1 px-2 border-r py-2" :class="{'hover:bg-gray-200 cursor-pointer': !isInSidebarMode}">{{project.year}}</div> <div class="flex-1 px-2 py-2" :class="{'hover:bg-gray-200 cursor-pointer': !isInSidebarMode}">{{project.director}}</div> <div class="w-4"> <div class="ion-ios-arrow-forward text-gray-700 hidden group-hover-block pl-1" v-if="isInSidebarMode"></div> </div> </div> </div> </div> </div> </div> <div class="h-screen flex flex-col flex-1 overflow-scroll" :class="{'border-l': !doShowFullScreenActors}" v-if="doShowProjectDetails && isInSidebarMode"> <div class="h-10 flex px-3 items-center"> <button class="ion-md-close text-xl px-2 text-gray-700 hover:bg-gray-200 rounded" @click="doShowProjectDetails = false; selectedProject = null;" v-if="!doShowFullScreenActors"></button> <button class="ion-md-expand text-xl px-2 text-gray-700 hover:bg-gray-200 rounded mx-2" @click="doShowFullScreenActors = true" v-if="!doShowFullScreenActors"> </button> <div class="flex items-center" v-if="doShowFullScreenActors"> <div class="w-3 h-3 mr-1 bg-gray-300 rounded-full"></div> <div class="w-3 h-3 mr-1 bg-gray-300 rounded-full"></div> <div class="w-3 h-3 mr-2 bg-gray-300 rounded-full"></div> <div class="mx-1 px-1 w-5 h-5 bg-gray-300 rounded"></div> </div> <button class="px-2 ion-md-arrow-back text-xl rounded text-gray-400" :class="{'text-gray-700': doShowFullScreenActors, 'hover:bg-gray-200': doShowFullScreenActors}" @click="backPressedActors()"></button> <button class="px-2 ion-md-arrow-forward text-xl rounded text-gray-400"></button> <div class="mx-1 px-1 w-12 h-3 bg-gray-300 rounded"></div> <div class="text-gray-400">/</div> <div class="mx-1 px-1 w-12 h-3 bg-gray-300 rounded"></div> <div class="flex-1"></div> <div class="mx-1 px-1 w-12 h-3 bg-gray-300 rounded"></div> <div class="mx-1 px-1 w-12 h-3 bg-gray-300 rounded"></div> <div class="mx-1 px-1 w-12 h-3 bg-gray-300 rounded"></div> <div class="mx-1 px-1 w-5 h-5 bg-gray-300 rounded"></div> </div> <div class="flex-1 overflow-scroll"> <div class="h-56 bg-cover bg-center" :style="{backgroundImage: 'url('+ projects[selectedProject].cover + ')'}"></div> <div class="px-8" :class="{'px-16': doShowFullScreenActors && !doShowActorDetails}"> <div class="text-3xl font-bold mb-3 mt-5">{{projects[selectedProject].name}}</div> <div class="border-b pb-4 mb-4"> <div class="flex items-center"> <div class="w-24"> <div class="mx-1 px-1 w-16 h-3 bg-gray-300 rounded"></div> </div> <div> {{projects[selectedProject].year}} </div> </div> <div class="flex items-center"> <div class="w-24"> <div class="mx-1 px-1 w-16 h-3 bg-gray-300 rounded"></div> </div> <div> {{projects[selectedProject].director}} </div> </div> </div> <div class="pb-8"> <div class="flex items-center border-b py-2 mt-3"> <div class="text-lg font-semibold mr-2">Cast</div> <div class="mx-1 px-1 w-12 h-3 bg-gray-300 rounded"></div> <div class="flex-1"></div> <div class="mx-1 px-1 w-12 h-3 bg-gray-300 rounded"></div> <div class="mx-1 px-1 w-5 h-5 bg-gray-300 rounded"></div> <button class="ion-ios-more text-xl text-gray-600 mx-1 px-2 hover:bg-gray-200 rounded" @click="doShowMoreMenuActors = true"></button> <div class="relative"> <div class="fixed top-0 left-0 h-screen w-screen bg-white" style="opacity: 0.01" v-if="doShowMoreMenuActors" @click="doShowMoreMenuActors = false"></div> <div v-if="doShowMoreMenuActors" class="absolute bg-white w-48 shadow rounded text-sm" style="right: -12px; top: -32px;"> <div class="mx-3 px-1 my-3 w-24 h-3 bg-gray-300 rounded"></div> <div class="mx-3 px-1 my-3 w-16 h-3 bg-gray-300 rounded"></div> <div class="mx-3 px-1 my-3 w-16 h-3 bg-gray-300 rounded"></div> <div class="mx-3 px-1 my-3 w-24 h-3 bg-gray-300 rounded"></div> <div class="flex items-center px-3 py-1 border-t border-b hover:bg-gray-200 cursor-pointer" @click="isInSidebarModeActors = !isInSidebarModeActors"> <div>Split-screen</div> <div class="flex-1"></div> <div class="w-8 h-5 bg-gray-400 rounded-full flex" :class="{'justify-end bg-blue-500': isInSidebarModeActors}"> <div class="h-5 w-5 rounded-full bg-white border-2 border-gray-400" :class="{'border-blue-500': isInSidebarModeActors}"></div> </div> </div> <div class="mx-3 px-1 my-3 w-16 h-3 bg-gray-300 rounded"></div> <div class="mx-3 px-1 my-3 w-24 h-3 bg-gray-300 rounded"></div> </div> </div> <div class="mx-1 px-1 w-12 h-6 bg-blue-400 rounded"></div> </div> <div class="flex border-b text-sm"> <div class="flex-1 px-2 border-r py-3"> <div class="w-16 h-2 bg-gray-300 rounded"></div> </div> <div class="flex-1 px-2 border-r py-3"> <div class="w-16 h-2 bg-gray-300 rounded"></div> </div> <div class="flex-1 px-2 py-3"> <div class="w-16 h-2 bg-gray-300 rounded"></div> </div> <div class="w-4"></div> </div> <div v-for="actor, i in projects[selectedProject].actors" class="flex border-b text-sm group items-center" :class="{'hover:bg-gray-200 cursor-pointer': isInSidebarModeActors, 'bg-gray-200': selectedActor === i}" @click="rowPressedActors(i)"> <div class="flex-1 px-2 border-r py-2 flex item-center group "> <div class="flex-1">{{actor.name}}</div> <button class="uppercase text-xs border rounded px-1 hidden group-hover-block" @click="openPressedActors(i)" v-if="!isInSidebarModeActors">Open</button> </div> <div class="flex-1 px-2 border-r py-2" :class="{'hover:bg-gray-200 cursor-pointer': !isInSidebarModeActors}">{{actor.role}}</div> <div class="flex-1 px-2 py-2" :class="{'hover:bg-gray-200 cursor-pointer': !isInSidebarModeActors}">{{actor.born}}</div> <div class="w-4"> <div class="ion-ios-arrow-forward text-gray-700 hidden group-hover-block pl-1" v-if="isInSidebarModeActors"></div> </div> </div> </div> <div class="text-2xl font-bold pb-2">Plot</div> <textarea class="w-full" style="height: 700px;" v-model="projects[selectedProject].content"></textarea> </div> </div> </div> <div class="h-screen flex flex-col flex-1 overflow-scroll border-l" v-if="doShowActorDetails && isInSidebarModeActors"> <div class="h-10 flex px-3 items-center"> <button class="ion-md-close text-xl px-2 text-gray-700 hover:bg-gray-200 rounded" @click="doShowActorDetails = false; selectedActor = null;"></button> <div class="px-2 w-5 h-5 bg-gray-300 rounded" style="margin-left: .83rem; margin-right: .83rem;"></div> <button class="px-2 ion-md-arrow-back text-xl rounded text-gray-400" :class="{'text-gray-700': !doShowFullScreenActors, 'hover:bg-gray-200': !doShowFullScreenActors}" @click="backPressedActorDetails()"></button> <button class="px-2 ion-md-arrow-forward text-xl rounded text-gray-400"></button> <div class="mx-1 px-1 w-12 h-3 bg-gray-300 rounded"></div> <div class="text-gray-400">/</div> <div class="mx-1 px-1 w-12 h-3 bg-gray-300 rounded"></div> <div class="flex-1"></div> <div class="mx-1 px-1 w-12 h-3 bg-gray-300 rounded"></div> <div class="mx-1 px-1 w-12 h-3 bg-gray-300 rounded"></div> <div class="mx-1 px-1 w-12 h-3 bg-gray-300 rounded"></div> <div class="mx-1 px-1 w-5 h-5 bg-gray-300 rounded"></div> </div> <div class="flex-1 px-8 overflow-scroll"> <div class="h-16"></div> <div class="text-3xl font-bold mb-3">{{projects[selectedProject].actors[selectedActor].name}}</div> <div class="border-b pb-4 mb-4"> <div class="flex items-center"> <div class="w-24"> <div class="mx-1 px-1 w-16 h-3 bg-gray-300 rounded"></div> </div> <div> {{projects[selectedProject].actors[selectedActor].role}} </div> </div> <div class="flex items-center"> <div class="w-24"> <div class="mx-1 px-1 w-16 h-3 bg-gray-300 rounded"></div> </div> <div> {{projects[selectedProject].actors[selectedActor].born}} </div> </div> </div> <div class="text-2xl font-bold pb-2">Bio</div> <textarea class="w-full" style="height: 700px;" v-model="projects[selectedProject].actors[selectedActor].bio"></textarea> </div> </div> </div> <div v-if="doShowProjectDetails && !isInSidebarMode"> <div class="fixed top-0 left-0 h-screen w-screen bg-black opacity-50"></div> <div class="fixed top-0 left-0 h-screen w-screen flex items-center justify-center pt-12 pb-16 px-4" @click="doShowProjectDetails = false; selectedProject = null"> <div class="bg-white rounded w-full max-w-3xl shadow-lg h-full flex flex-col" @click.stop=""> <div class="h-10 flex px-3 items-center border-b border-gray-200"> <div class="mx-1 px-1 w-5 h-5 bg-gray-300 rounded"></div> <div class="mx-1 px-1 w-12 h-3 bg-gray-300 rounded"></div> <div class="flex-1"></div> <div class="mx-1 px-1 w-12 h-3 bg-gray-300 rounded"></div> <div class="mx-1 px-1 w-12 h-3 bg-gray-300 rounded"></div> <div class="mx-1 px-1 w-12 h-3 bg-gray-300 rounded"></div> <div class="mx-1 px-1 w-5 h-5 bg-gray-300 rounded"></div> </div> <div class="flex-1 overflow-scroll"> <div class="h-56 bg-cover bg-center" :style="{backgroundImage: 'url('+ projects[selectedProject].cover + ')'}"></div> <div class="px-12"> <div class="text-3xl font-bold mt-5 mb-3">{{projects[selectedProject].name}}</div> <div class="border-b pb-4 mb-4"> <div class="flex items-center"> <div class="w-24"> <div class="mx-1 px-1 w-16 h-3 bg-gray-300 rounded"></div> </div> <div> {{projects[selectedProject].year}} </div> </div> <div class="flex items-center"> <div class="w-24"> <div class="mx-1 px-1 w-16 h-3 bg-gray-300 rounded"></div> </div> <div> {{projects[selectedProject].director}} </div> </div> </div> <textarea class="w-full" style="height: 700px;" v-model="projects[selectedProject].content"></textarea> </div> </div> </div> </div> </div> <div v-if="doShowActorDetails && !isInSidebarModeActors"> <div class="fixed top-0 left-0 h-screen w-screen bg-black opacity-50"></div> <div class="fixed top-0 left-0 h-screen w-screen flex items-center justify-center pt-12 pb-16 px-4" @click="doShowActorDetails = false; selectedActor = null"> <div class="bg-white rounded w-full max-w-3xl shadow-lg h-full flex flex-col" @click.stop=""> <div class="h-10 flex px-3 items-center border-b border-gray-200"> <div class="mx-1 px-1 w-5 h-5 bg-gray-300 rounded"></div> <div class="mx-1 px-1 w-12 h-3 bg-gray-300 rounded"></div> <div class="flex-1"></div> <div class="mx-1 px-1 w-12 h-3 bg-gray-300 rounded"></div> <div class="mx-1 px-1 w-12 h-3 bg-gray-300 rounded"></div> <div class="mx-1 px-1 w-12 h-3 bg-gray-300 rounded"></div> <div class="mx-1 px-1 w-5 h-5 bg-gray-300 rounded"></div> </div> <div class="flex-1 px-12 overflow-scroll"> <div class="h-16"></div> <div class="text-3xl font-bold mb-3">{{projects[selectedProject].actors[selectedActor].name}}</div> <div class="border-b pb-4 mb-4"> <div class="flex items-center"> <div class="w-24"> <div class="mx-1 px-1 w-16 h-3 bg-gray-300 rounded"></div> </div> <div> {{projects[selectedProject].actors[selectedActor].role}} </div> </div> <div class="flex items-center"> <div class="w-24"> <div class="mx-1 px-1 w-16 h-3 bg-gray-300 rounded"></div> </div> <div> {{projects[selectedProject].actors[selectedActor].born}} </div> </div> </div> <div class="text-2xl font-bold pb-2">Bio</div> <textarea class="w-full" style="height: 700px;" v-model="projects[selectedProject].actors[selectedActor].bio"></textarea> </div> </div> </div> </div> </div> <script type="text/javascript" src="http://repo.bfw.wiki/bfwrepo/js/vue@2.6.1.js"></script> <script> var app = new Vue({ el: '#app', data: { projects: [ { name: 'Jules and Jim', year: '1962', director: 'François Truffaut', content: 'The film is set before, during, and after the Great War in several different parts of France, Austria, and Germany. Jules (Oskar W.........完整代码请登录后点击上方下载按钮下载查看
网友评论0