CSS Flex 布局实现无缝滚动


当前第2页 返回上一页

思路:

  • 首先分析这个小demo的结构,上下结构,我们可以用一个容器,将其包裹(就是所谓的大盒子)。

  • 上方是个导航,上边是个ul,下面我们就可以用两个p,宽度的100%,高度自定义。

  • 接下来我们就来开启和模型,记住一定的父盒子哦!display:flex;,那么怎么上下分呢?在继续添加 flex-wrap: wrap;就是上下分离了,是不是很方便。

  • 接下来就是下边部分了,p里嵌套了ul,而且ul的高度好理解,是p的高度,那么ul多少宽呢?,可以无限宽!!! 我们让ul的宽度是3000px

  • 我们接下来放li,你一看,li里面的也是上下结构,所以呢,嘿嘿!li是不是也要开启flex呀 flex-wrap: wrap;。上方p是放img,下边一个a标签。

  • 记住哦,li用浮动起来哦!并考虑overflow:hidden放在那里

动画效果

  • 我们有五张图片,我们现在让它从右向左移动。那么我们叫ul移动,带动li移动是不是可以。

  • 我们用@keyframes改变ul的left的值,但是问题来了,我放五张图片,ul移动,右边就没了,空白了。肿么办???

  • 我们是不是可以将五个li,在后面再复制一份,放在后边呀。 答案是可以的!!当我们的left正好将第一组li,移除,那么第二组就刚好不上来。那么我们用 animation: run 20s linear infinite;无限循环是不是就好了。

css部分代码

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

86

87

88

89

90

91

92

93

94

* {

    margin: 0;

    padding: 0;

}

 

a {

    text-decoration: none;

}

 

.box-big {

    position: absolute;

    display: flex;

    left: 50%;

    top: 50%;

    border: 1px solid #9FD6FF;

    transform: translate(-50%, -50%);

    width: 707px;

    height: 170px;

    /* background-color: pink; */

    flex-wrap: wrap;

    overflow: hidden;

}

 

.box-top {

    width: 707px;

    height: 30px;

    border-bottom: 1px solid #9FD6FF;

    background-color: #FEFEFE;

}

 

.p-bottom {

    width: 707px;

    height: 136px;

    /* background-color: darkgoldenrod; */

    overflow: hidden;

}

 

.st-icon-android {

    display: inline-block;

    width: 15px;

    height: 15px;

    background-image: url(../img/hd.gif);

    margin: 8px;

}

 

h5 {

    position: absolute;

    top: 6PX;

    left: 30px;

    color: #307DD1;

}

 

ul {

    position: absolute;

    left: 90px;

    width: 3000px;

    height: 100%;

    animation: run 20s linear infinite;

}

 

li {

    list-style: none;

    float: left;

    width: 140px;

    height: 100%;

    margin: 0 5px 0 5px;

    /* background-color: gold; */

    flex-wrap: wrap;

}

 

.photo {

    margin-top: 5px;

    width: 140px;

    height: 105px;

    text-align: center;

    /* background-color: springgreen; */

}

 

p {

    text-align: center;

}

 

img {

    cursor: pointer;

}

 

@keyframes run {

    0% {

        left: 0;

    }

    100% {

        left: -745px;

    }

}

推荐教程:《CSS教程》

以上就是CSS Flex 布局实现无缝滚动的详细内容,更多文章请关注木庄网络博客

返回前面的内容

相关阅读 >>

如何通过Flex进行网页布局

移动端图片无缝滚动是如何实现的?(代码)

css3 Flex布局总结

Flex是什么?

css Flex 布局 space-between 最后一行左对齐

Flex布局和grid布局实例分享

css Flex 的用途详解

css Flex 布局实现无缝滚动

Flex布局和传统的布局有什么不同

更多相关阅读请进入《Flex》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...