IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> 头条VUE代码 -> 正文阅读

[JavaScript知识库]头条VUE代码

main.js

import Vue from 'vue'

import App from './App.vue'

import router from './router/index'

Vue.config.productionTip = false

new Vue({

? render: h => h(App),

? router

}).$mount('#app')

路由配置

import Vue from 'vue'

import VueRouter from 'vue-router'

import Home from '../page/Home.vue'

import Detail from '../page/Detail.vue'

Vue.use(VueRouter)

let router = new VueRouter({

routes:[

? ? {

? ? ? ? path:'/',

? ? ? ? component:Home

? ? },

? ? {

? ? ? ? path:'/detail/:id',

? ? ? ? props:true,

? ? ? ? component:Detail

? ? }

]

})

export default router

APP.vue

<template>

? <div id="app">

? ?<router-view></router-view>

? </div>

</template>

<script>


?

export default {

? name: 'App',

? components: {

? ?

? }

}

</script>

<style>

*{

? ? margin: 0;

? ? padding: 0;

? ? list-style: none;

? ? text-decoration: none;

? ? outline: none;

}

.flex{

? display: flex;

}

.j-c{

? justify-content: center;

}

.j-s{

? justify-content: space-between;

}

.a-c{

? align-items: center;

}

a{

? ? color: black;

}

#app {

? /* width: 1200px; */

? /* margin: 0 auto; */

? /* border: 1px solid #ccc; */

}

</style>

Header.vue

<template>

? <div class="head flex j-s a-c">

? ? <img class="img1" src="/image/index/message.png" alt="" />

? ? <div class="center flex a-c j-c">

? ? ? <img class="img2" src="/image/index/wap_logo.png" alt="" />

? ? ? <img class="img3" src="/image/index/titlebar_refresh.png" alt="" />

? ? </div>

? ? <img class="img1" src="/image/index/search_normal.png" alt="" />

? </div>

</template>

<script>

export default {

? name: "Header",

};

</script>

<style scoped>

.head {

? ? width: 100vw;

? height: 40px;

? background-color: #d33d3e;

? position: fixed;

? top: 0;

? left: 0;

}

.head .center {

? flex: 1;

}

.img1{

? ? width: 36px;

}

.head .img2{

? ? width: 122px;

}

.head .img3{

? ? width: 24px;

}

</style>

news.vue?

?

<template>

<div class="news">

? ? <router-link :to="`/detail/${item.id}`" v-for="(item,index) in news" :key="index">

? ? ? ? <div class="flex item j-s a-c">

? ? ? ? <div class="left">

? ? ? ? ? ? <div class="title">{{item.title}}</div>

? ? ? ? ? ? <div class="flex">

? ? ? ? ? ? ? ? <div class="zd">置顶</div>

? ? ? ? ? ? ? ? <div class="pl">{{item.from}}</div>

? ? ? ? ? ? ? ? <div class="pl">评论 {{item.commentLength}}</div>

? ? ? ? ? ? </div>

? ? ? ? </div>

? ? ? ? <div class="right">

? ? ? ? ? ? <img :src="item.img">

? ? ? ? </div>

? ? </div>

? ? </router-link>

</div>

</template>

<script>

import axios from 'axios'

export default {

name:'News',

data() {

? ? return {

? ? ? ? news:[]

? ? }

},

created() {

? ? axios.get('/data/data.json').then(({data})=>{

? ? ? ? this.news = data

? ? ? ? // console.log(this.news);

? ? })

},

}

</script>

<style scoped>

.news{

? ? padding: 5px 10px;

? ? margin-top: 40px;

}

.item{

? ? border-bottom: 1px solid #eee;

? ? padding: 10px 0;

}

.title{

? ? margin-bottom: 5px;

}

.zd{

? ? border: 1px solid #d33d3e;

? ? color: #d33d3e;

? ? padding: 0 2px;

? ? font-size: 12px;

}

.pl{

? ? color: #666;

? ? font-size: 12px;

? ? margin: 0 4px;

}

.right img{

? ? width: 100px;

}

</style>

detail.vue

?

<template>

? <div class="detail">

? ? <div class="title">{{ item.title }}</div>

? ? <div class="flex a-c">

? ? ? <img class="logo" src="/image/datails/author.jpg" />

? ? ? <div class="center" style="margin-left: 10px">

? ? ? ? <div class="from">{{ item.from }}</div>

? ? ? ? <div class="time flex a-c">

? ? ? ? ? {{ item.time | filterTime }}<span>评论{{ item.commentLength }}</span>

? ? ? ? ? <div class="btn">关注</div>

? ? ? ? </div>

? ? ? </div>

? ? </div>

? ? <div v-html="item.content"></div>

? </div>

</template>

<script>

import axios from "axios";

// import moment from "moment";

import wfl from '../utils/wfl.js'

// console.log(moment);

export default {

? name: "Detail",

? props: ["id"],

? data() {

? ? return {

? ? ? item: {},

? ? };

? },

? created() {

? ? axios.get("/data/data.json").then(({ data }) => {

? ? ? this.item = data.find((r) => r.id === this.id);

? ? ? // console.log(this.item);

? ? });

? },

? filters: {

? ? filterTime(val) {

? ? ? return wfl.formatData(val)

? ? },

? },

};

</script>

<style scoped>

.detail {

? padding: 10px;

}

.title {

? font-weight: bold;

? font-size: 20px;

}

.logo {

? width: 30px;

? border-radius: 50%;

}

.center {

? padding: 5px 0;

}

.from {

? font-size: 14px;

? font-weight: bold;

}

.time {

? font-size: 12px;

}

.time span {

? margin-left: 2px;

? color: #f85a59;

}

.btn {

? font-size: 14px;

? height: 25px;

? width: 40px;

? text-align: center;

? line-height: 25px;

? padding: 2px 10px;

? color: white;

? background-color: #f85a59;

? margin-left: 10px;

}

</style>

?Home.vue

?

<template>

<div>

? ? <Header></Header>

? ? <News></News>

</div>

</template>

<script>

import Header from '../components/Header.vue'

import News from '../components/News.vue'

export default {

name:'Home',

components:{

? ? Header,

? ? News

}

}

</script>

<style scoped>

</style>

wfl.js

?

let formatData = (val, now = new Date) => {

? ? let time = now - new Date(val)

? ? return parseInt(time / 1000 / 60 / 60) + '小时前'

}

export default{

? ? formatData

}

?

?

?

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2021-11-20 18:18:19  更:2021-11-20 18:19:04 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/4 10:07:13-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码