无法替换变量[Javascript]

时间:2012-02-19 05:07:16

标签: javascript google-chrome

我试图修改Google Code Javascript文件,以便获得链接访问的经验。我是javascript的新手,我真的不知道如何说出我想要做的事情。我认为它应该是这样的:

var exp = 0 //Current exp
var level = 1; // User Level
var tolvl = level * 100 //Exp to 'level up'

function expchange (exp) {
  if (urlToCount <= 1) { //if they have visited the link once today
    exp+=10; //Change variable 'exp' to "variable"+10
  }
  else {
    exp+=5; // If more, change to "variable"+5
  }
  if (exp == tolvl ) { //If Variable 'exp' is equal to Variable 'tolvl'
    level+=1; //Change variable 'level' to 'variable'+1
}
//I need some kind of function to write Variables to HTML

我可能做了一些可怕的错误,对不好的脚本感到抱歉。谢谢你的帮助

整个代码供参考:

// Copyright (c) 2012 The Chromium Authors. All rights reserved.
// Event listner for clicks on links in a browser action popup.
// Open the link in a new tab of the current window.
function onAnchorClick(event) {
  chrome.tabs.create({
    selected: true,
    url: event.srcElement.href
  });
  return false;
}

// Given an array of URLs, build a DOM list of those URLs in the
// browser action popup.
function buildPopupDom(divName, data) {
  var popupDiv = document.getElementById(divName);

  var ul = document.createElement('ul');
  popupDiv.appendChild(ul);

  for (var i = 0, ie = data.length; i < ie; ++i) {
    var a = document.createElement('a');
    a.href = data[i];
    a.appendChild(document.createTextNode(data[i]));
    a.addEventListener('click', onAnchorClick);

    var li = document.createElement('li');
    li.appendChild(a);

    ul.appendChild(li);
  }
}

// Search history to find up to ten links that a user has typed in,
// and show those links in a popup.
function buildTypedUrlList(divName) {
  // To look for history items visited in the last week,
  // subtract a week of microseconds from the current time.
  var microsecondsPerDay = 1000 * 60 * 60 * 24 ;
  var onedayAgo = (new Date).getTime() - microsecondsPerDay;

  // Track the number of callbacks from chrome.history.getVisits()
  // that we expect to get.  When it reaches zero, we have all results.
  var numRequestsOutstanding = 0;

  chrome.history.search({
      'text': '',              // Return every history item....
      'startTime': oneDayAgo  // that was accessed less than one week ago.
    },
    function(historyItems) {
      // For each history item, get details on all visits.
      for (var i = 0; i < historyItems.length; ++i) {
        var url = historyItems[i].url;
        var processVisitsWithUrl = function(url) {
          // We need the url of the visited item to process the visit.
          // Use a closure to bind the  url into the callback's args.
          return function(visitItems) {
            processVisits(url, visitItems);
          };
        };
        chrome.history.getVisits({url: url}, processVisitsWithUrl(url));
        numRequestsOutstanding++;
      }
      if (!numRequestsOutstanding) {
        onAllVisitsProcessed();
      }
    });


  // Maps URLs to a count of the number of times the user typed that URL into
  // the omnibox.
  var urlToCount = {};

  // Callback for chrome.history.getVisits().  Counts the number of
  // times a user visited a URL by typing the address.
  var processVisits = function(url, visitItems) {
    for (var i = 0, ie = visitItems.length; i < ie; ++i) {
      // Ignore items unless the user typed the URL.
      if (visitItems[i].transition != 'link') {
        continue;
      }

      if (!urlToCount[url]) {
        urlToCount[url] = 0;
      }

      urlToCount[url]++;
    }

    // If this is the final outstanding call to processVisits(),
    // then we have the final results.  Use them to build the list
    // of URLs to show in the popup.
    if (!--numRequestsOutstanding) {
      onAllVisitsProcessed();
    }
  };

  // This function is called when we have the final list of URls to display.
  var onAllVisitsProcessed = function() {
    // Get the top scorring urls.
    urlArray = [];
    for (var url in urlToCount) {
      urlArray.push(url);
    }

    // Sort the URLs by the number of times the user typed them.
    urlArray.sort(function(a, b) {
      return urlToCount[b] - urlToCount[a];
    });

    buildPopupDom(divName, urlArray.slice(0, 10));
  };
}

document.addEventListener('DOMContentLoaded', function () {
  buildTypedUrlList("typedUrl_div");
});
var exp = 0 //Current exp
var level = 1; // User Level
var tolvl = level * 100 //Exp to 'level up'

function expchange (exp) {
  if (urlToCount <= 1) { //if they have visited the link once today
    exp+=10; //Change variable 'exp' to "variable"+10
  }
  else {
    exp+=5; // If more, change to "variable"+5
  }
  if (exp == tolvl ) { //If Variable 'exp' is equal to Variable 'tolvl'
    level+=1; //Change variable 'level' to 'variable'+1
}
//I need some kind of function to write Variables to HTML

1 个答案:

答案 0 :(得分:1)

阅读并重新阅读您的代码后,我认为您需要这样的东西。 不确定tolvl计算,但其余的应该显示在何处以及如何更改

// Copyright (c) 2012 The Chromium Authors. All rights reserved.
// Event listner for clicks on links in a browser action popup.
// Open the link in a new tab of the current window.
var urlToCount = {};
function onAnchorClick(event) {
  chrome.tabs.create({
    selected: true,
    url: event.srcElement.href
  });
  return false;
}

// Given an array of URLs, build a DOM list of those URLs in the
// browser action popup.
function buildPopupDom(divName, data) {
  var popupDiv = document.getElementById(divName);

  var ul = document.createElement('ul');
  popupDiv.appendChild(ul);

  for (var i = 0, ie = data.length; i < ie; ++i) {
    var a = document.createElement('a');
    a.href = data[i];
    a.appendChild(document.createTextNode(data[i]));
    var info  = urllToCount[data[i]]
    a.addEventListener('click', onAnchorClick);

    var li = document.createElement('li');
    li.appendChild(a);
    li.appendChild(document.createTextNode("- level:"+info.level));
    li.appendChild(document.createTextNode("- exp:"+info.ext));
    li.appendChild(document.createTextNode("- visits:"+info.visits));

    ul.appendChild(li);
  }
}

// Search history to find up to ten links that a user has typed in,
// and show those links in a popup.
function buildTypedUrlList(divName) {
  // To look for history items visited in the last week,
  // subtract a week of microseconds from the current time.
  var microsecondsPerDay = 1000 * 60 * 60 * 24 ;
  var onedayAgo = (new Date).getTime() - microsecondsPerDay;

  // Track the number of callbacks from chrome.history.getVisits()
  // that we expect to get.  When it reaches zero, we have all results.
  var numRequestsOutstanding = 0;

  chrome.history.search({
      'text': '',              // Return every history item....
      'startTime': oneDayAgo  // that was accessed less than one week ago.
    },
    function(historyItems) {
      // For each history item, get details on all visits.
      for (var i = 0; i < historyItems.length; ++i) {
        var url = historyItems[i].url;
        var processVisitsWithUrl = function(url) {
          // We need the url of the visited item to process the visit.
          // Use a closure to bind the  url into the callback's args.
          return function(visitItems) {
            processVisits(url, visitItems);
          };
        };
        chrome.history.getVisits({url: url}, processVisitsWithUrl(url));
        numRequestsOutstanding++;
      }
      if (!numRequestsOutstanding) {
        onAllVisitsProcessed();
      }
    });


  // Maps URLs to a count of the number of times the user typed that URL into
  // the omnibox.

  // Callback for chrome.history.getVisits().  Counts the number of
  // times a user visited a URL by typing the address.
  var processVisits = function(url, visitItems) {
    for (var i = 0, ie = visitItems.length; i < ie; ++i) {
      // Ignore items unless the user typed the URL.
      if (visitItems[i].transition != 'link') {
        continue;
      }

      if (!urlToCount[url]) {
        urlToCount[url].visits = 0;
        urlToCount[url].exp = 0;
        urlToCount[url].level = 0;

      }

      urlToCount[url].visits++;
    }

    // If this is the final outstanding call to processVisits(),
    // then we have the final results.  Use them to build the list
    // of URLs to show in the popup.
    if (!--numRequestsOutstanding) {
      onAllVisitsProcessed();
    }
  };

  // This function is called when we have the final list of URls to display.
  var onAllVisitsProcessed = function() {
    // Get the top scoring urls.
    var level = 1; // User Level
    var tolvl = level * 100 //Exp to 'level up'
    urlArray = [];
    for (var url in urlToCount) {
      urlArray.push(url);
      urlToCount[url].exp += (urlToCount[url].visits<=1)?10:5; // 5 if visited more than once
      if (urlToCount[url].exp>=tolvl) urlToCount[url].level++;  
    }

    // Sort the URLs by the number of times the user typed them.
    urlArray.sort(function(a, b) {
      return urlToCount[b].visits - urlToCount[a].visits;
    });

    buildPopupDom(divName, urlArray.slice(0, 10));
  };
}

document.addEventListener('DOMContentLoaded', function () {
  buildTypedUrlList("typedUrl_div");
});