Angular7教程

Stella981
• 阅读 663

1. 本节说明

本节以及后面的内容我们将会通过搭建一个简单的博客程序来对angular进行介绍,项目使用前端框架是bootstrap.版本v3.3.7,另外需要安装jquery.关于bootstrap,jquery的安装方法第一篇中有讲解,不再赘述。本节内容由于搭建页面框架的关系,主要是bootstrap的内容,与angular关系不太大。最后的效果如下:

Angular7教程

2. 搭建框架

首先,我们将上面的页面大致分为5个区域,分别是头部(header),轮播图(carousel),文章区域(article),侧边栏(sidebar),底部(footer)。

进入到项目目录,分别创建这5个组件:

ng g c header
ng g c carousel
ng g c artile
ng g c sidebar
ng g c footer

3. 编写模板文件和CSS文件

主要是bootstrap和css的内容,下面贴出文件的源码,不再做详细解释:

3.1. app.component.html

<app-header></app-header>
<div class="container">
    <div class="row">
        <div class="col-md-9">
            <app-carousel></app-carousel>
            <app-article></app-article>
        </div>
        <div class="col-md-3">
            <app-sidebar></app-sidebar>
        </div>
    </div>
</div>
<app-footer></app-footer>

3.2. 全局样式文件 style.css

/* You can add global styles to this file, and also import other style files */
html,body{
    margin: 0;
    padding: 0;
    font-size: 12px;
    background-color: rgb(243,243,243) !important;
}
body{
    padding-top: 70px;
}

3.3. header.component.html

<nav class="navbar navbar-default navbar-fixed-top" role="navigation">
    <div class="container">
        <div class="navbar-header">
            <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target=".navbar-ex">
                <span class="icon-bar"></span>
                <span class="icon-bar"></span>
                <span class="icon-bar"></span>
            </button>
            <a href="" class="navbar-brand">博客家</a>
        </div>
        <div class="collapse navbar-collapse navbar-ex">
            <ul class="nav navbar-nav">
                <li><a href="#">首页</a></li>
                <li><a href="#">联系我们</a></li>
                <li><a href="#">关于我们</a></li>
            </ul>
            <form class="navbar-form navbar-left">
                <div class="form-group">
                    <input type="text" class="form-control" placeholder="搜索内容">
                </div>
                &nbsp;<button type="submit" class="btn btn-default">Search</button>
            </form>
            <div class="navbar-nav navbar-right">
                <button class="navbar-btn btn btn-info">登录</button>&nbsp;
                <button class="navbar-btn btn btn-defualt">注册</button>
            </div>
            <!--
            <ul class="nav navbar-nav navbar-right">
                <li class="dropdown">
                    <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button"
                    aria-haspopup="true" aria-expanded="false">
                    <span class="glyphicon glyphicon-user"></span> <span class="caret"></span></a>
                    <ul class="dropdown-menu">
                        <li><a href="#">我的博客</a></li>
                        <li><a href="#">我的收藏</a></li>
                        <li><a href="#">站内信</a></li>
                        <li role="separator" class="divider"></li>
                        <li><a href="#">个人中心</a></li>
                        <li><a href="#">帐号设置</a></li>
                    </ul>
                </li>
            </ul>
            -->
        </div>
    </div>
</nav>

3.4. carousel.component.html

<div id="carousel-ex" class="carousel slide" data-ride="carousel">
    <ol class="carousel-indicators">
        <li data-target="carousel-ex" data-slide-to="0" class="active"></li>
        <li data-target="carousel-ex" data-slide-to="1"></li>
        <li data-target="carousel-ex" data-slide-to="2"></li>
    </ol>

    <div class="carousel-inner listbox">
        <div class="item active">
            <img src="https://via.placeholder.com/900X300" alt="">
            <div class="carousel-caption">
                图片一
            </div>
        </div>
        <div class="item">
            <img src="https://via.placeholder.com/900X300" alt="">
            <div class="carousel-caption">
                图片二
            </div>
        </div>
        <div class="item">
            <img src="https://via.placeholder.com/900X300" alt="">
            <div class="carousel-caption">
                图片三
            </div>
        </div>
    </div>

    <a href="#carousel-ex" class="left carousel-control" role="button" data-slide="prev">
        <span class="glyphicon glyphicon-chevron-left" aria-hidden="true"></span>
        <span class="sr-only">Previous</span>
    </a>
    <a href="#carousel-ex" class="right carousel-control" role="button" data-slide="next">
        <span class="glyphicon glyphicon-chevron-right" aria-hidden="true"></span>
        <span class="sr-only">Next</span>
    </a>
</div>

3.5. article.component.html

<div class="content-wrap">
    <div class="article">
        <h3 class="title">Angular常用操作</h3>
        <p class="zy">
            本节来介绍angular中的操作以及TypeScript语法的简单介绍。关于TypeScript语法的更为详细的内容,
            打算在整个angular教程结束后再单独介绍...
        </p>
        <p class="info">
            <span>2018-11-18 21:15:</span>&nbsp;&nbsp;
            <span>阅读数:37</span>&nbsp;&nbsp;
            <span>评论数:2</span>&nbsp;&nbsp;
        </p>
    </div>
    <div class="article">
        <h3 class="title">Angular常用操作</h3>
        <p class="zy">
            本节来介绍angular中的操作以及TypeScript语法的简单介绍。关于TypeScript语法的更为详细的内容,
            打算在整个angular教程结束后再单独介绍...
        </p>
        <p class="info">
            <span>2018-11-18 21:15:</span>&nbsp;&nbsp;
            <span>阅读数:37</span>&nbsp;&nbsp;
            <span>评论数:2</span>&nbsp;&nbsp;
        </p>
    </div>
    <div class="article">
        <h3 class="title">Angular常用操作</h3>
        <p class="zy">
            本节来介绍angular中的操作以及TypeScript语法的简单介绍。关于TypeScript语法的更为详细的内容,
            打算在整个angular教程结束后再单独介绍...
        </p>
        <p class="info">
            <span>2018-11-18 21:15:</span>&nbsp;&nbsp;
            <span>阅读数:37</span>&nbsp;&nbsp;
            <span>评论数:2</span>&nbsp;&nbsp;
        </p>
    </div>
    <div class="article">
        <h3 class="title">Angular常用操作</h3>
        <p class="zy">
            本节来介绍angular中的操作以及TypeScript语法的简单介绍。关于TypeScript语法的更为详细的内容,
            打算在整个angular教程结束后再单独介绍...
        </p>
        <p class="info">
            <span>2018-11-18 21:15:</span>&nbsp;&nbsp;
            <span>阅读数:37</span>&nbsp;&nbsp;
            <span>评论数:2</span>&nbsp;&nbsp;
        </p>
    </div>

</div>

3.6. article.component.css

.content-wrap{
    box-shadow: 0 0 3px rgb(220, 220, 220);
    background: white;
}
.article{
    padding: 10px;
    margin: 5px 0px;
    border-bottom: 1px solid rgb(240,240,240);
}

.article h3{
    font-size: 18px;
    font-weight: bold;
    color: #333;
    font-family: "SF Pro Display",Roboto,Noto,Arial,"PingFang SC",sans-serif;
}
.zy{
    font-size: 14px;
    color: #999;
    letter-spacing: 0.5px;
    font-family: "SF Pro Display",Roboto,Noto,Arial,"PingFang SC",sans-serif;
}

.info{
    color: #6b6b6b;
    margin-top: 10px;
}

3.7. sidebar.component.html

<div class="panel panel-info hot">
    <div class="panel-heading">
        热门文章
    </div>
    <div class="panel-body">
        <div class="media">
            <div class="media-left">
                <a href="#">
                    <img src="https://via.placeholder.com/64" alt="" class="media-object">
                </a>
            </div>
            <div class="media-body">
                <h4 class="media-heading">JDK环境变量配置</h4>
                <p>JDK环境变量配置,首先从官网下载对应版本..</p>
            </div>
        </div>
        <div class="media">
            <div class="media-left">
                <a href="#">
                    <img src="https://via.placeholder.com/64" alt="" class="media-object">
                </a>
            </div>
            <div class="media-body">
                <h4 class="media-heading">JDK环境变量配置</h4>
                <p>JDK环境变量配置,首先从官网下载对应版本..</p>
            </div>
        </div>
        <div class="media">
            <div class="media-left">
                <a href="#">
                    <img src="https://via.placeholder.com/64" alt="" class="media-object">
                </a>
            </div>
            <div class="media-body">
                <h4 class="media-heading">JDK环境变量配置</h4>
                <p>JDK环境变量配置,首先从官网下载对应版本..</p>
            </div>
        </div>
        <div class="media">
            <div class="media-left">
                <a href="#">
                    <img src="https://via.placeholder.com/64" alt="" class="media-object">
                </a>
            </div>
            <div class="media-body">
                <h4 class="media-heading">JDK环境变量配置</h4>
                <p>JDK环境变量配置,首先从官网下载对应版本..</p>
            </div>
        </div>
    </div>
</div>

3.8. sidebar.component.css

.hot h4{
    margin-top: 0;
}
.hot .media-body h4{
    color: #333;
    font-size: 16px;
}
.hot .media-body p{
    color: #999;
    font-size:12px;
}

3.9. footer.component.html

<div class="container">
    <hr>
    <footer>
        <div class="row">
            <div class="col-lg-12">footer部分</div>
        </div
    </footer>
</div>
点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
Wesley13 Wesley13
3年前
java将前端的json数组字符串转换为列表
记录下在前端通过ajax提交了一个json数组的字符串,在后端如何转换为列表。前端数据转化与请求varcontracts{id:'1',name:'yanggb合同1'},{id:'2',name:'yanggb合同2'},{id:'3',name:'yang
Easter79 Easter79
3年前
swap空间的增减方法
(1)增大swap空间去激活swap交换区:swapoff v /dev/vg00/lvswap扩展交换lv:lvextend L 10G /dev/vg00/lvswap重新生成swap交换区:mkswap /dev/vg00/lvswap激活新生成的交换区:swapon v /dev/vg00/lvswap
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
待兔 待兔
4个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Jacquelyn38 Jacquelyn38
3年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Easter79 Easter79
3年前
Twitter的分布式自增ID算法snowflake (Java版)
概述分布式系统中,有一些需要使用全局唯一ID的场景,这种时候为了防止ID冲突可以使用36位的UUID,但是UUID有一些缺点,首先他相对比较长,另外UUID一般是无序的。有些时候我们希望能使用一种简单一些的ID,并且希望ID能够按照时间有序生成。而twitter的snowflake解决了这种需求,最初Twitter把存储系统从MySQL迁移
Wesley13 Wesley13
3年前
00:Java简单了解
浅谈Java之概述Java是SUN(StanfordUniversityNetwork),斯坦福大学网络公司)1995年推出的一门高级编程语言。Java是一种面向Internet的编程语言。随着Java技术在web方面的不断成熟,已经成为Web应用程序的首选开发语言。Java是简单易学,完全面向对象,安全可靠,与平台无关的编程语言。
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
10个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这