Rumah > hujung hadapan web > tutorial css > 使用css3和jQuery实现文字跟随鼠标的上下抖动

使用css3和jQuery实现文字跟随鼠标的上下抖动

不言
Lepaskan: 2018-06-20 14:46:57
asal
1969 orang telah melayarinya

这篇文章主要介绍了jQuery+css3实现文字跟随鼠标的上下抖动的相关资料,需要的朋友可以参考下

css3过渡属性结合jq,如果直接复制代码运行,需要加载一个jquery文件

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

95

96

97

98

99

100

101

102

103

104

105

106

107

108

109

110

111

112

113

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml">

<head>

<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />

<title>m</title>

</head>

<style>

/* CSS 预设*/

*{ margin:0; padding:0;}

a{ text-decoration:none;}

img{ border:none;}

ul{ list-style:none;}

body{ color:#222121; font-size:12px; font-family:"宋体"; background-color:#fefefe}

.clearfix:after{ content:"."; display:block; height:0; clear:both; overflow:hidden;}

.clearfix{ zoom:1;}

/*clear*/

.left{float:left;}

.right{float:right;}

.clear{clear:both;}

/*demo4*/

.demo{ margin:0 50px;}

.hover-list{ line-height:40px; width:500px;}

.hover-list li{ height:40px; border-bottom:1px solid #969; position:relative;}

.hover-list li a span{ width:12px; height:40px;cursor:pointer;transition:all .1s cubic-bezier(.06,1.15,1,1.4) 0s;}

.hover-list li a{ color:#39F; cursor:pointer;}

</style>

<body>

<p class="demo">

  <p class="wrapper box-con">   

    <ul class="hover-list">

      <li><a href="http://www.miaov.com/2013/#" target="_blank">我们内地,大红撒谎道夫们内地道夫们内地</a></li>

      <li><a href="#2">方法我阿道道夫们内地夫们内大红撒谎道夫们内地道夫们内地地,大红撒谎</a></li>

      <li><a href="#2">是我们内地,道夫们内地大红撒谎</a></li>

      <li><a href="#2">大红撒方法我阿道道夫们内地夫们内大红撒谎道夫们内地道夫们内地地谎</a></li>

      <li><a href="#2">我们内地,大红撒谎道夫们内地道夫们内地</a></li>

      <li><a href="#2">方法我阿道道夫们内地夫们内大红撒谎道夫们内地道夫们内地地,大红撒谎</a></li>

      <li><a href="#2">是我们内地,道夫们内地大红撒谎</a></li>

    </ul>

  </p>

</body>

<script src="js/jquery-1.10.2.js"></script>

<script type="text/javascript">

$(function(){

  

//demo

  //可以变化的参数

  var setccid=$(".hover-list");//设置ul的class,添加效果

  var setleft=12;//设置字与字之间的left值

  var setskip=10;//设置上下抖动值

    

  var hov=setccid.children("li");

  for(var i=0;i<hov.length;i++){

    var hovtext=hov.eq(i).find("a").html();

    var hovtextl=hovtext.length;

    //alert(hovtextl)

    var hovtexta=hovtext.split("");

    var arrys=[];

    for(var j=0;j<hovtexta.length;j++){

      arrys.push(hovtexta[j].replace(hovtexta[j],"<span>"+hovtexta[j]+"</span>"))

    };

    hov.eq(i).find("a").html(arrys);

    var hovtextspan=hov.eq(i).find("a").find("span").length;

    for(var z=0;z<hovtextspan;z++){

      hov.eq(i).find("a").find("span").eq(z).css({position:"absolute",top:"0px"});

      hov.eq(i).find("a").find("span").eq(z).css(&#39;left&#39;,z*setleft);

    }

  };

    

  setccid.children("li").find("a").children("span").hover(function(event){

    var sppz=$(this).index();

    var sppzp=$(this).parent().children("span");

    var sppzpl=$(this).parent().children("span").length;

    var sppy=$(this).offset().top;

    var ey=event.pageY;

    var chay=sppy+$(this).height()/2;

    var sppcony=$(this).position().top;

    if(ey>=chay) {

      $(this).css(&#39;top&#39;,sppcony+setskip);

      var lla=sppcony+setskip;

      var lll=lla;

      var llr=lla;

      var teshu=(sppz-lla)>0?sppz-lla:0;   

      for(var xx=sppz+1;xx<=sppz+lla;xx++){

        llr=llr-1;

        sppzp.eq(xx).css(&#39;top&#39;,llr);  

      };

      for(var x=sppz-1;x>=teshu;x--){

        lll=lll-1;

        sppzp.eq(x).css(&#39;top&#39;,lll);

      };

    }else{

      $(this).css(&#39;top&#39;,sppcony-setskip);

      var lla=sppcony-setskip;

      var lll=lla;

      var llr=lla;

      var teshu=(sppz+lla)>0?sppz+lla:0;

      for(var xxxx=sppz+1;xxxx<=sppz-lla;xxxx++){

        llr=llr+1;

        sppzp.eq(xxxx).css(&#39;top&#39;,llr);

      };

      for(var xxx=sppz-1;xxx>=teshu;xxx--){

        lll=lll+1;

        sppzp.eq(xxx).css(&#39;top&#39;,lll);

      };          

    }   

  },function(event){

    $(this).css(&#39;top&#39;,"0px");

    $(this).parent().children("span").css(&#39;top&#39;,"0px");

  });

//end   

});

</script>

</html>

Salin selepas log masuk

以上就是本文的全部内容,希望对大家的学习有所帮助,更多相关内容请关注PHP中文网!

相关推荐:

如何使用CSS的pointer-events属性实现鼠标穿透效果

CSS3和Javascript实现进度条的效果

Atas ialah kandungan terperinci 使用css3和jQuery实现文字跟随鼠标的上下抖动. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan