IJavaScript无法正常工作/链接

时间:2014-12-16 20:48:30

标签: javascript jquery html css

我最近开始学习HTML,CSS和Javascript,我仍然掌握它。

我希望在单击div类(mainLeft)时显示隐藏菜单(菜单)。但是,我的javascript查询隐藏/显示它不起作用。

HTML代码

<head>

  <link type="text/css" rel="stylesheet" href="satmap.css" />
 <script type="text/javascript" src="C:\Users\mbashir\Documents\HTML\satmap.js"></script>

<title>SATMAP Home</title>
</head>

 <body>

    <div id="main">
    <h1> XYZ</h1>
    </div>

  <div id="mainLeft">
    <h1> Current Stats </h1>
  </div>

  <div id="SME">
    <h4> my Explorer </h4>
  </div>

  <div id="DataAnalysis">
    <h4> Data Analysis </h4>
  </div>

  <div id="ProdMonitor">
    <h4> Production Monitoring </h4>
  </div>

    <div class="menu">

  <div class="icon-close">
    <h4> Disappear </h4>
  </div>

  <ul>
    <li><a href="#">Gain Table</a></li>
    <li><a href="#"> Remember Me</a></li>
    </ul>
</div>

</body>

CSS代码

 body {
  background-color: white;
}

h1{
font-size: 30px;
  color: white;
  display: table-cell;
  text-align: center;
  vertical-align: middle;
  font-family: Candara; 
}

h4{
font-size: 30px;
  color: white;
  display: table-cell;
  text-align: center;
  vertical-align: middle;
  font-family: Candara; 
}

#main {
  display: table;
  height: 50px;
  width: 600px;
  margin-left: auto;
  margin-right: auto;
  background-color: #13b5ea;
}
#SME {
  display: table;
  position: absolute;
  width: 250px;
  height: 250px;
  left: 50%;
  top: 50%;
  margin-left: -125px;
  margin-top: -125px;
  background-color:#13b5ea;
}

#DataAnalysis {
  display: table;
  position: absolute;
  width: 200px;
  height: 200px;
  left: 38.3%;
  top: 28%;
  margin-left: -100px;
  margin-top: -100px;
  background-color:#13b5ea;
}

#ProdMonitor {
  display: table;
  background-color:#13b5ea;
  position: absolute;
  width: 200px;
  height: 200px;
  left: 38.3%;
  top: 72%;
  margin-left: -100px;
  margin-top: -100px;
   }

#mainLeft {
  display: table;
  height: 50px;
  width: 600px;
  margin-right: auto;
  background-color: #13b5ea;
  cursor: pointer;
}

    .menu {
  background-color:#13b5ea;
  left: -285px;  
  height: 100%;
  position: fixed;
  width: 285px;
}
  .menu ul {
  border-top: 1px solid #636366;
  list-style: none;
  margin: 0;
  padding: 0;
}

.menu li {
  border-bottom: 1px solid #636366;
  font-family: 'Open Sans', sans-serif;
  line-height: 45px;
  padding-bottom: 3px;
  padding-left: 20px;
  padding-top: 3px;
}

.menu a {
  color: #fff;
  font-size: 15px;
  text-decoration: none;
  text-transform: uppercase;
}

.icon-close {
  cursor: pointer;
  padding-left: 10px;
  padding-top: 10px;
}

Javascript代码

var main = function(){
  $('#mainLeft').click(function(){
      $('.menu').animate({
          left:'0px'
     },200);

    $('body').animate({
      left: '285px'
    }, 200);
   });
};


$(document).ready(main);

2 个答案:

答案 0 :(得分:1)

您是否确认过您的javascript正在解雇?比如添加console.log('test')alert('test')?如果它正在开火,那么你可以继续看其他事情。

我认为您的问题可能是因为您为left值设置了动画并不具有任何意义,因为这些元素尚未获得CSS position值使用它。尝试给#mainLeft元素position: absolute,看看会发生什么。

答案 1 :(得分:0)

您说JS文件与页面位于同一文件夹中,因此您可以将其链接为:

<script src="satmap.js"></script>

另请注意,在提供的HTML中,您没有包含JQuery Library,并且由于您使用的编码依赖于JQuery,这将是一个问题! :)
您可以从JQuery.com下载JQuery库,或链接到CDN主机,如:

<script src="//code.jquery.com/jquery-1.11.0.min.js"></script>
<script src="//code.jquery.com/jquery-migrate-1.2.1.min.js"></script>