-3

サイトをブログとして使用することを検討していました。セットアップは完了しましたが、サイド ナビゲーション ボタンを使用しようとすると、次の JavaScript エラーが発生します。

Object function (a,b){return new e.fn.init(a,b,h)} has no method 'url' [http://127.0.0.1:8000/static/js/components/links.js:15]

ここにlinks.jsがあります:

var $url;

function setupLinks() {

  $('a').click(function(e) {
      if (e.which == 2)
          return;

      e.preventDefault();
      e.stopPropagation();

      if (this.href == $url)
          return;

      var url = $.url(this.href.replace('/#!', ''));
      $url = this.href;

      if (this.id == 'home-link' && window.location.pathname == '/') {
         $('#github-profile').remove();
         $('#dribbble-profile').remove();
         $('#twitter-profile').remove();
         $('#instagram-profile').remove();
         $('#lastfm-profile').remove();
         $('.modal-backdrop').remove();
         adjustSelection('home-link');
      }
      else if(this.id == 'instagram-link' && instagram_integration_enabled) {
         $('#github-profile').remove();
         $('#dribbble-profile').remove();
         $('#twitter-profile').remove();
         $('#lastfm-profile').remove();
         $('.modal-backdrop').remove();
         adjustSelection('instagram-link');

         setupInstagram(this);
      }
      else if (twitter_integration_enabled && (url.attr('host') == 'twitter.com' || url.attr('host') == 'www.twitter.com')) {

         $('#github-profile').remove();
         $('#dribbble-profile').remove();
         $('#instagram-profile').remove();
         $('#lastfm-profile').remove();
         $('.modal-backdrop').remove();
         adjustSelection('twitter-link');

         setupTwitter(url, this);
      }
      else if (github_integration_enabled && (url.attr('host') == 'github.com' || url.attr('host') == 'www.github.com')) {

        $('#twitter-profile').remove();
        $('#dribbble-profile').remove();
        $('#instagram-profile').remove();
        $('#lastfm-profile').remove();
        $('.modal-backdrop').remove();
        adjustSelection('github-link');

        setupGithub(url, this);
      }
      else if (dribbble_integration_enabled && (url.attr('host') == 'dribbble.com' || url.attr('host') == 'www.dribbble.com')) {

         $('#twitter-profile').remove();
         $('#github-profile').remove();
         $('#instagram-profile').remove();
         $('#lastfm-profile').remove();
         $('.modal-backdrop').remove();
         adjustSelection('dribbble-link');

         setupDribbble(url, this);
      }
      else if (lastfm_integration_enabled && (url.attr('host') == 'lastfm.com' || url.attr('host') == 'www.lastfm.com')) {

        $('#twitter-profile').remove();
        $('#github-profile').remove();
        $('#dribbble-profile').remove();
        $('#instagram-profile').remove();
        $('.modal-backdrop').remove();
        adjustSelection('lastfm-link');

        setupLastfm(url, this);
      }
      else {
         window.location = this.href;
      }
  });
}

function adjustSelection(el) {
  $('.main-nav').children('li').removeClass('sel');
  $('#' + el).parent().addClass('sel');

  if (el == 'home-link')
    $url = null;
}

これは、欠落している JavaScript ライブラリの問題のようです。Syte のインストール手順では、サイトをデプロイする前に compress.py を実行する必要があります。JavaScriptライブラリを自動インポートして圧縮することになっていますが、そうしていないようです。これがcompress.pyです:

import os
import sys
import subprocess
import shlex
import traceback

path_to_here = os.path.abspath(os.path.dirname(__file__))
path_before_site = path_to_here[0:path_to_here.rfind('syte')]
sys.path.append(path_before_site)
os.environ['DJANGO_SETTINGS_MODULE'] = 'syte.settings'

from django.conf import settings

def compress_statics():
    try:
        #This won't work on windows.
        subprocess.check_call(shlex.split('mkdir -p static/css static/js/min'))
    except Exception:
        print 'Make sure to create "syte > static > css" and "syte > static > js > min" before compressing statics.'

    compress_styles()
    compress_js()

def compress_styles():
    less_path = 'static/less/styles.less'
    css_path = 'static/css/'

    try:
        subprocess.check_call(shlex.split('lessc {0} {1}styles-{2}.min.css -yui-compress'
            .format(less_path, css_path, settings.COMPRESS_REVISION_NUMBER)))
        print 'CSS Styles Generated: styles-{0}.min.css'.format(settings.COMPRESS_REVISION_NUMBER)
    except Exception:
        exc_type, exc_value, exc_traceback = sys.exc_info()
        stack_trace = traceback.format_exception(exc_type, exc_value, exc_traceback)
        print stack_trace

def compress_js():
    js_files = [
      'libs/jquery.url.js',
      'libs/require.js',
      'libs/handlebars.js',
      'libs/moment.min.js',
      'libs/bootstrap-modal.js',
      'libs/spin.min.js',
      'libs/prettify.js',

      'components/base.js',
      'components/mobile.js',
      'components/blog-posts.js',
      'components/links.js',
    ]

    if settings.TWITTER_INTEGRATION_ENABLED:
        js_files.append('components/twitter.js')

    if settings.GITHUB_INTEGRATION_ENABLED:
        js_files.append('components/github.js')

    if settings.DRIBBBLE_INTEGRATION_ENABLED:
        js_files.append('components/dribbble.js')

    if settings.INSTAGRAM_INTEGRATION_ENABLED:
        js_files.append('components/instagram.js')

    if settings.DISQUS_INTEGRATION_ENABLED:
        js_files.append('components/disqus.js')

    if settings.LASTFM_INTEGRATION_ENABLED:
        js_files.append('components/lastfm.js')

    combined = ''
    for js in js_files:
        f = open('static/js/' + js, 'r')
        combined += f.read()
        f.close()

    f = open('static/js/combined.js', 'w')
    f.write(combined)
    f.close()

    try:
        subprocess.check_call(shlex.split('uglifyjs -o static/js/min/scripts-{0}.min.js static/js/combined.js'.format(settings.COMPRESS_REVISION_NUMBER)))
        subprocess.check_call(shlex.split('rm -f static/js/combined.js'))
        print 'JavaScript Combined and Minified: scripts-{0}.min.js'.format(settings.COMPRESS_REVISION_NUMBER)
    except Exception:
        exc_type, exc_value, exc_traceback = sys.exc_info()
        stack_trace = traceback.format_exception(exc_type, exc_value, exc_traceback)
        print stack_trace

if __name__ == "__main__":
    compress_statics()
    sys.exit()

私のjavascriptスキルが不足しているので、どんな助けでも大歓迎です!

4

3 に答える 3

1

ページに依存関係を含めていない可能性が最も高く、具体的にはjquery.url.js

リストされているすべての依存関係を含めると、機能するはずです。

于 2012-07-26T21:21:32.313 に答える
0

問題は、干渉している tumblr 投稿の 1 つに JavaScript を埋め込んでいたことでした。JavaScript を削除し、現在は修正されています。

于 2012-07-27T17:14:16.143 に答える
0
var url = $.url(this.href.replace('/#!', '')); 

$.url が存在しません

于 2012-07-26T21:19:43.483 に答える