因此,我是Java,CSS和HTML的新手,并且正在从事一个雄心勃勃的项目。在这一点上,我们称其为荣耀的任务管理器。我已经设法通过书籍和在线资源来解决这个问题。现在,我只是试图充实UI并试图使主要的html文件与.js文件进行对话,而该.js文件又与另一个.html文件和.json文件进行对话。我还没有打扰过CSS。我想我可以在稍作工作后就可以这样做。这是我认为相关的代码。

主要HTML(usetime.html):

<!DOCTYPE html>

<body>
    <header>
        <h1>UseTime</h1>
        <nav>
            <a href="jq-load.html">HOME</a>
            <a href="jq-load.html2">PROFILE</a>
            <a href="jq-load.html4">MANAGE TASKS</a>
            <a href="usetime.html">TIME TABLE</a>
        </nav>
    </header>
    <section id="content">
        <div id="container">
            <div class="third">
                <div id="event">
                    <a id="class1" href="class1.html"><img src="" alt="class1" /> Class 1 </a>
                    <a id="class2" href="class2.html"><img src="" alt="class2" /> Class 2 </a>
                    <a id="class3" href="class3.html"><img src="" alt="class3" /> Class 3 </a>
                </div>
            </div>
            <div class="third">
                <div id="sessions"> Select a Class from the left </div>
            </div>
            <div class="third">
                <div id="details"> Details </div>
            </div>
        </div>
        <!-- container -->
    </section>
    <!-- content -->

    <script src="js/jquery-3.2.1.slim.min.js"></script>
    <script src="js/example.js"></script>
</body>


和应该处理所有内容的.js文件(example.js):

$(function () { //when the DOM is ready
    var times; //declare global variable
    $.ajax({ //set up request
        beforeSend: function (xhr) { //before requesting data
            if (xhr.overrideMimeType) { //if supported
                xhr.overrideMimeType("applicaition/json"); // set MIME to prevent errors
            }

        }
    });
    //funciton that colleges data from the json file
    fucntion loadTimetable() { //decalre function
        $.getJSON('data/example.json') //try to collect json data
            .done(function (data) { //if succesful
                times = data; //store in variable

            }).fail(fuction() { //if a problem: show message
                $('#event').html('Sorry! we couldnt load your time table at the moment');
            });
    }

    loadTimetable(); //call the function

    //CLICK ON TEH EVENT TO LOAD A TIME TABLE
    $('#content').on('click', '#event a', funciton(e) { //user clicks on place
        e.preventDefault(); //prevent loading page
        var loc = this.id.toUpperCase(); //get value of id attr

        var newContent = "";
        for (var i = 0; i < times[loc].length; i++) { // loop through sessions
            newContent += '<li><span class = "time">' + times[loc][i].time + '</span>';
            newContent += < a href = "descriptions.html#';
            newContent += times[loc][i].title.replace(/ /g, '-') + '">';
            newContent += times[loc][i].title + '</a></li>';
        }

        $('#sessions').html('<ul>' + newContent + '</ul>'); // Display Time

        $('#event a.current').removeClass('current'); // update selected link
        $(this).addClass('current');

        $('#details').text('');

    });

    //CLICK ON A SESSION TO LEAD THE DESCRIPTION

    $('#content').on('click', '#sessions li a', funciton(e) { //click on session
        e.preventDefault(); // prevent loading
        var fragment = this.href //title is in href

        fragment = fragment.replace('#', ' #'); //Add Space before #
        $('#details').load(fragment); //to load info

        $('#sessions a.current').removeClass('current'); //update selected
    });

    //CLICK ON PRIMARY NAVIGATION
    $('nav a').on('click', function (e) { //click on nav
        e.preventDefault(); //prevent loading
        var url = this.href //get UR: to load

        $('nav a.current').removeClass('current');
        $(this).addClass('current');

        $('#container').remove(); //remove old
        $('#content').load(url + ' #container').hide().fadeIn('slow'); // add new

    });
});


另外还有一个example.json文件,只有几行,而我在同一个“ usetime”文件夹中有jquery 3.2.1.slim

我很沮丧,任何帮助将不胜感激。谢谢

编辑(我不是很清楚我的问题):好吧,当我运行第一个usetime html代码(应该执行其他东西)时,我所看到的只是usetime html的内容。我不确定发生了什么问题或如何解决。

最佳答案

您的大多数问题是“功能”拼写错误的结果。我也发现此错误:

newContent += <a href = "descriptions.html#';


您缺少开始的',应该是:

newContent += '<a href = "descriptions.html#';


纠正所有语法错误后,您的代码应该可以工作:

的JavaScript

$(function() { //when the DOM is ready
  var times; //declare global variable
  $.ajax({ //set up request
    beforeSend: function(xhr) { //before requesting data
      if (xhr.overrideMimeType) { //if supported
        xhr.overrideMimeType("applicaition/json"); // set MIME to prevent errors
      }
    }
  });
  //funciton that colleges data from the json file
  function loadTimetable() { //decalre function
    $.getJSON('data/example.json') //try to collect json data
      .done(function(data) { //if succesful
        times = data; //store in variable
      }).fail(function() { //if a problem: show message
        $('#event').html('Sorry! we couldnt load your time table at the moment');
      });
  }
  loadTimetable(); //call the function

  //CLICK ON TEH EVENT TO LOAD A TIME TABLE
  $('#content').on('click', '#event a', function(e) { //user clicks on place
    e.preventDefault(); //prevent loading page
    var loc = this.id.toUpperCase(); //get value of id attr
    var newContent = "";
    for (var i = 0; i < times[loc].length; i++) { // loop through sessions
      newContent += '<li><span class = "time">' + times[loc][i].time + '</span>';
      newContent += '<a href = "descriptions.html#';
      newContent += times[loc][i].title.replace(/ /g, '-') + '">';
      newContent += times[loc][i].title + '</a></li>';
    }
    $('#sessions').html('<ul>' + newContent + '</ul>'); // Display Time
    $('#event a.current').removeClass('current'); // update selected link
    $(this).addClass('current');
    $('#details').text('');
  });

  //CLICK ON A SESSION TO LEAD THE DESCRIPTION
  $('#content').on('click', '#sessions li a', function(e) { //click on session
    e.preventDefault(); // prevent loading
    var fragment = this.href; //title is in href
    fragment = fragment.replace('#', ' #'); //Add Space before #
    $('#details').load(fragment); //to load info
    $('#sessions a.current').removeClass('current'); //update selected
  });

  //CLICK ON PRIMARY NAVIGATION
  $('nav a').on('click', function(e) { //click on nav
    e.preventDefault(); //prevent loading
    var url = this.href; //get UR: to load
    $('nav a.current').removeClass('current');
    $(this).addClass('current');
    $('#container').remove(); //remove old
    $('#content').load(url + ' #container').hide().fadeIn('slow'); // add new
  });
});

关于javascript - 我不确定我是否从.js脚本正确调用.html和.json文件,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/44210073/

10-11 23:24
查看更多