2017-08-13 179 views
-1

我搜索了一個答案,但沒有一個適合。我是網站建設新手。我正在建立一個選項卡功能,改變頁面上的內容(代碼ex來自https://codepen.io/cssjockey/pen/jGzuK美元符號未定義

當我在我的嘗試。我收到一個錯誤,說明'$' is undefined。 這裏是我的代碼

的index.html

<!DOCTYPE html> 
<html 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 
<title>My Site</title> 
<meta name="keywords" content="" /> 
<meta name="description" content="" /> 
<link href="default.css" rel="stylesheet" type="text/css" media="all" /> 
<script language="JavaScript" src="functions.js"></script> 
</head> 
<body> 
<div class="container"> 

<ul class="tabs"> 
    <li class="tab-link current" data-tab="tab-1">TabA</li> 
    <li class="tab-link" data-tab="tab-2">TabB</li> 
    <li class="tab-link" data-tab="tab-3">TabC</li> 
    <li class="tab-link" data-tab="tab-4">TabD</li> 
</ul> 

<div id="tab-1" class="tab-content current"> 
    Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. 
</div> 
<div id="tab-2" class="tab-content"> 
    Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum. 
</div> 
<div id="tab-3" class="tab-content"> 
    Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. 
</div> 
<div id="tab-4" class="tab-content"> 
    Sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. 
</div> 

functions.js

$(document).ready(function(){ 

$('ul.tabs li').click(function(){ 
    var tab_id = $(this).attr('data-tab'); 

    $('ul.tabs li').removeClass('current'); 
    $('.tab-content').removeClass('current'); 

    $(this).addClass('current'); 
    $("#"+tab_id).addClass('current'); 
}) 

}) 

我感謝所有幫助可用!

+3

你還記得包括jQuery嗎?我沒有看到它在你的代碼 – Dekel

+0

回聲@Dekel:jquery不包括在內。 – tibetty

+1

請閱讀jQuery教程:https://learn.jquery.com/about-jquery/how-jquery-works/。 –

回答

2

這是因爲,美元符號($)是jQuery library usage.

要包含在您的項目,只需從他們的CDN導入:

<script 
    src="https://code.jquery.com/jquery-3.2.1.min.js" 
    integrity="sha256-hwg4gsxgFZhOsEEamdOYGBf13FyQuiTwlAQgxVSNgt4=" 
    crossorigin="anonymous"></script> 

因此,所有的所有<head>標籤應該看像這樣:

<head> 
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 
<title>My Site</title> 
<meta name="keywords" content="" /> 
<meta name="description" content="" /> 
<link href="default.css" rel="stylesheet" type="text/css" media="all" /> 
<script 
    src="https://code.jquery.com/jquery-3.2.1.min.js" 
    integrity="sha256-hwg4gsxgFZhOsEEamdOYGBf13FyQuiTwlAQgxVSNgt4=" 
    crossorigin="anonymous"></script> 
<script language="JavaScript" src="functions.js"></script> 
</head> 
+0

你真了不起! AND 14?!?!恭喜!謝謝! – TylerIlGenio

+0

@TylerIlGenio年齡不重要,只有你知道多少,以及你能學到多少東西。並沒有問題,如果它回答你的問題,請接受和upvote,如果你可以。 –