2017-01-03 48 views
1

我使用this包。我已经在slug函数的开头添加了这些console.log为什么我无法读取属性'toString'的undefined

function slug(string, opts) { 
    console.log('log 1: -------'); 
    console.log('log 2: ' + string); 
    console.log('log 3: ' + typeof string); 
    string = string.toString(); 
    .... 
} 

这里是输出:

log 1: ------- 
log 2: Yüzey Aktif Maddeler 
log 3: string 
/Users/------/seeder/node_modules/mongodb/lib/utils.js:99 
    process.nextTick(function() { throw err; }); 
           ^

TypeError: Cannot read property 'toString' of undefined 
    at slug (/Users/------/seeder/node_modules/slug/slug.js:16:20) 
    at Object.createSlug (/Users/------/seeder/seeder/utils.js:4:9) 
    at getContent (/Users/------/seeder/seeder/content-seeder.js:345:22) 
    at topic.contents.forEach.content (/Users/------/seeder/seeder/content-seeder.js:425:31) 
    at Array.forEach (native) 
    at /Users/------/seeder/seeder/content-seeder.js:424:21 
    at /Users/------/seeder/node_modules/mongodb/lib/collection.js:523:5 
    at /Users/------/seeder/node_modules/mongodb/lib/collection.js:701:5 
    at handleCallback (/Users/------/seeder/node_modules/mongodb/lib/utils.js:96:56) 
    at executeCommands (/Users/------/seeder/node_modules/mongodb/lib/bulk/ordered.js:405:12) 

即使字符串参数的类型是一个字符串,string.toString()抛出一个TypeError。它说字符串是未定义的。

我不是一个有经验的js开发人员。为什么会发生?

编辑: 我把它从这个功能

function getContent(content, categoryId) { 
    console.log(content.topicVideo); 
    return { 
     // _id: Random.id(), 
     // other properties 
     contentSlug: slug(content.topicVideo.contentName, { 
      lower: true 
     }) 
    }; 
} 

新日志:

{ id: '197505065', 
    categorySort: 18, 
    categoryName: 'Hayatımızda Kimya', 
    contentSort: 2, 
    contentName: 'Yüzey Aktif Maddeler', 
    fileName: 'KonuAnlatimi.mp4' } 

编辑:

我在塞函数的末尾添加一个日志。

console.log(result); 
    return result; 
}; 

这打印结果,然后抛出错误。

log 1: ------- 
log 2: Yüzey Aktif Maddeler 
log 3: string 
log 4: Yüzey Aktif Maddeler 
yuzey-aktif-maddeler 

编辑:我觉得这行给出了一个暗示:

/Users/------/seeder/node_modules/mongodb/lib/utils.js:99 
    process.nextTick(function() { throw err; }); 

我认为它会记录正确的字符串,但未定义的一个出现故障,而无需登录日志。这可能吗?我发现其中一个content.topicVideo.contentName实际上是未定义的。但是如果没有记录它,就会抛出错误。这甚至有可能吗?

+3

你确定它正在抛出这个确切的线?你能重现代码片段中的问题吗? –

+0

是的。我检查了行号 – osrl

+1

这不应该发生,你需要提供一个更完整的例子,否则我们不能真正帮助你。 –

回答

2

也许你应该检查是否字符串有falsy值和(可选的,如果它不是一个字符串)

function slug(string, opts) { 
    console.log('log 1: -------'); 
    console.log('log 2: ' + string); 
    console.log('log 3: ' + typeof string); 
    if(string) 
     string = string.toString(); 
    .... 
} 

从MDN:

Falsy

A falsy value is a value that translates to false when evaluated in a Boolean context.

更多falsy值在JavaScript here

2

以下代码正常工作(将slug.js模块添加到要测试的脚本中)。也许这会帮助你分析你的代码?

(function (root) { 
 
// lazy require symbols table 
 
var _symbols, removelist; 
 
function symbols(code) { 
 
    if (_symbols) return _symbols[code]; 
 
    _symbols = require('unicode/category/So'); 
 
    removelist = ['sign','cross','of','symbol','staff','hand','black','white'] 
 
     .map(function (word) {return new RegExp(word, 'gi')}); 
 
    return _symbols[code]; 
 
} 
 

 
function slug(string, opts) { 
 
    string = string.toString(); 
 
    if ('string' === typeof opts) 
 
     opts = {replacement:opts}; 
 
    opts = opts || {}; 
 
    opts.mode = opts.mode || slug.defaults.mode; 
 
    var defaults = slug.defaults.modes[opts.mode]; 
 
    var keys = ['replacement','multicharmap','charmap','remove','lower']; 
 
    for (var key, i = 0, l = keys.length; i < l; i++) { key = keys[i]; 
 
     opts[key] = (key in opts) ? opts[key] : defaults[key]; 
 
    } 
 
    if ('undefined' === typeof opts.symbols) 
 
     opts.symbols = defaults.symbols; 
 

 
    var lengths = []; 
 
    for (var key in opts.multicharmap) { 
 
     if (!opts.multicharmap.hasOwnProperty(key)) 
 
      continue; 
 

 
     var len = key.length; 
 
     if (lengths.indexOf(len) === -1) 
 
      lengths.push(len); 
 
    } 
 

 
    var code, unicode, result = ""; 
 
    for (var char, i = 0, l = string.length; i < l; i++) { char = string[i]; 
 
     if (!lengths.some(function (len) { 
 
      var str = string.substr(i, len); 
 
      if (opts.multicharmap[str]) { 
 
       i += len - 1; 
 
       char = opts.multicharmap[str]; 
 
       return true; 
 
      } else return false; 
 
     })) { 
 
      if (opts.charmap[char]) { 
 
       char = opts.charmap[char]; 
 
       code = char.charCodeAt(0); 
 
      } else { 
 
       code = string.charCodeAt(i); 
 
      } 
 
      if (opts.symbols && (unicode = symbols(code))) { 
 
       char = unicode.name.toLowerCase(); 
 
       for(var j = 0, rl = removelist.length; j < rl; j++) { 
 
        char = char.replace(removelist[j], ''); 
 
       } 
 
       char = char.replace(/^\s+|\s+$/g, ''); 
 
      } 
 
     } 
 
     char = char.replace(/[^\w\s\-\.\_~]/g, ''); // allowed 
 
     if (opts.remove) char = char.replace(opts.remove, ''); // add flavour 
 
     result += char; 
 
    } 
 
    result = result.replace(/^\s+|\s+$/g, ''); // trim leading/trailing spaces 
 
    result = result.replace(/[-\s]+/g, opts.replacement); // convert spaces 
 
    result = result.replace(opts.replacement+"$",''); // remove trailing separator 
 
    if (opts.lower) 
 
     result = result.toLowerCase(); 
 
    return result; 
 
}; 
 

 
slug.defaults = { 
 
    mode: 'pretty', 
 
}; 
 

 
slug.multicharmap = slug.defaults.multicharmap = { 
 
    '<3': 'love', '&&': 'and', '||': 'or', 'w/': 'with', 
 
}; 
 

 
// https://code.djangoproject.com/browser/django/trunk/django/contrib/admin/media/js/urlify.js 
 
slug.charmap = slug.defaults.charmap = { 
 
    // latin 
 
    'À': 'A', 'Á': 'A', 'Â': 'A', 'Ã': 'A', 'Ä': 'A', 'Å': 'A', 'Æ': 'AE', 
 
    'Ç': 'C', 'È': 'E', 'É': 'E', 'Ê': 'E', 'Ë': 'E', 'Ì': 'I', 'Í': 'I', 
 
    'Î': 'I', 'Ï': 'I', 'Ð': 'D', 'Ñ': 'N', 'Ò': 'O', 'Ó': 'O', 'Ô': 'O', 
 
    'Õ': 'O', 'Ö': 'O', 'Ő': 'O', 'Ø': 'O', 'Ù': 'U', 'Ú': 'U', 'Û': 'U', 
 
    'Ü': 'U', 'Ű': 'U', 'Ý': 'Y', 'Þ': 'TH', 'ß': 'ss', 'à':'a', 'á':'a', 
 
    'â': 'a', 'ã': 'a', 'ä': 'a', 'å': 'a', 'æ': 'ae', 'ç': 'c', 'è': 'e', 
 
    'é': 'e', 'ê': 'e', 'ë': 'e', 'ì': 'i', 'í': 'i', 'î': 'i', 'ï': 'i', 
 
    'ð': 'd', 'ñ': 'n', 'ò': 'o', 'ó': 'o', 'ô': 'o', 'õ': 'o', 'ö': 'o', 
 
    'ő': 'o', 'ø': 'o', 'ù': 'u', 'ú': 'u', 'û': 'u', 'ü': 'u', 'ű': 'u', 
 
    'ý': 'y', 'þ': 'th', 'ÿ': 'y', 'ẞ': 'SS', 
 
    // greek 
 
    'α':'a', 'β':'b', 'γ':'g', 'δ':'d', 'ε':'e', 'ζ':'z', 'η':'h', 'θ':'8', 
 
    'ι':'i', 'κ':'k', 'λ':'l', 'μ':'m', 'ν':'n', 'ξ':'3', 'ο':'o', 'π':'p', 
 
    'ρ':'r', 'σ':'s', 'τ':'t', 'υ':'y', 'φ':'f', 'χ':'x', 'ψ':'ps', 'ω':'w', 
 
    'ά':'a', 'έ':'e', 'ί':'i', 'ό':'o', 'ύ':'y', 'ή':'h', 'ώ':'w', 'ς':'s', 
 
    'ϊ':'i', 'ΰ':'y', 'ϋ':'y', 'ΐ':'i', 
 
    'Α':'A', 'Β':'B', 'Γ':'G', 'Δ':'D', 'Ε':'E', 'Ζ':'Z', 'Η':'H', 'Θ':'8', 
 
    'Ι':'I', 'Κ':'K', 'Λ':'L', 'Μ':'M', 'Ν':'N', 'Ξ':'3', 'Ο':'O', 'Π':'P', 
 
    'Ρ':'R', 'Σ':'S', 'Τ':'T', 'Υ':'Y', 'Φ':'F', 'Χ':'X', 'Ψ':'PS', 'Ω':'W', 
 
    'Ά':'A', 'Έ':'E', 'Ί':'I', 'Ό':'O', 'Ύ':'Y', 'Ή':'H', 'Ώ':'W', 'Ϊ':'I', 
 
    'Ϋ':'Y', 
 
    // turkish 
 
    'ş':'s', 'Ş':'S', 'ı':'i', 'İ':'I', 
 
    'ğ':'g', 'Ğ':'G', 
 
    // russian 
 
    'а':'a', 'б':'b', 'в':'v', 'г':'g', 'д':'d', 'е':'e', 'ё':'yo', 'ж':'zh', 
 
    'з':'z', 'и':'i', 'й':'j', 'к':'k', 'л':'l', 'м':'m', 'н':'n', 'о':'o', 
 
    'п':'p', 'р':'r', 'с':'s', 'т':'t', 'у':'u', 'ф':'f', 'х':'h', 'ц':'c', 
 
    'ч':'ch', 'ш':'sh', 'щ':'sh', 'ъ':'u', 'ы':'y', 'ь':'', 'э':'e', 'ю':'yu', 
 
    'я':'ya', 
 
    'А':'A', 'Б':'B', 'В':'V', 'Г':'G', 'Д':'D', 'Е':'E', 'Ё':'Yo', 'Ж':'Zh', 
 
    'З':'Z', 'И':'I', 'Й':'J', 'К':'K', 'Л':'L', 'М':'M', 'Н':'N', 'О':'O', 
 
    'П':'P', 'Р':'R', 'С':'S', 'Т':'T', 'У':'U', 'Ф':'F', 'Х':'H', 'Ц':'C', 
 
    'Ч':'Ch', 'Ш':'Sh', 'Щ':'Sh', 'Ъ':'U', 'Ы':'Y', 'Ь':'', 'Э':'E', 'Ю':'Yu', 
 
    'Я':'Ya', 
 
    // ukranian 
 
    'Є':'Ye', 'І':'I', 'Ї':'Yi', 'Ґ':'G', 'є':'ye', 'і':'i', 'ї':'yi', 'ґ':'g', 
 
    // czech 
 
    'č':'c', 'ď':'d', 'ě':'e', 'ň': 'n', 'ř':'r', 'š':'s', 'ť':'t', 'ů':'u', 
 
    'ž':'z', 'Č':'C', 'Ď':'D', 'Ě':'E', 'Ň': 'N', 'Ř':'R', 'Š':'S', 'Ť':'T', 
 
    'Ů':'U', 'Ž':'Z', 
 
    // polish 
 
    'ą':'a', 'ć':'c', 'ę':'e', 'ł':'l', 'ń':'n', 'ś':'s', 'ź':'z', 
 
    'ż':'z', 'Ą':'A', 'Ć':'C', 'Ę':'E', 'Ł':'L', 'Ń':'N', 'Ś':'S', 
 
    'Ź':'Z', 'Ż':'Z', 
 
    // latvian 
 
    'ā':'a', 'ē':'e', 'ģ':'g', 'ī':'i', 'ķ':'k', 'ļ':'l', 'ņ':'n', 
 
    'ū':'u', 'Ā':'A', 'Ē':'E', 'Ģ':'G', 'Ī':'I', 
 
    'Ķ':'K', 'Ļ':'L', 'Ņ':'N', 'Ū':'U', 
 
    // lithuanian 
 
    'ė':'e', 'į':'i', 'ų':'u', 'Ė': 'E', 'Į': 'I', 'Ų':'U', 
 
    // romanian 
 
    'ț':'t', 'Ț':'T', 'ţ':'t', 'Ţ':'T', 'ș':'s', 'Ș':'S', 'ă':'a', 'Ă':'A', 
 
    // vietnamese 
 
    'Ạ': 'A', 'Ả': 'A', 'Ầ': 'A', 'Ấ': 'A', 'Ậ': 'A', 'Ẩ': 'A', 'Ẫ': 'A', 
 
    'Ằ': 'A', 'Ắ': 'A', 'Ặ': 'A', 'Ẳ': 'A', 'Ẵ': 'A', 'Ẹ': 'E', 'Ẻ': 'E', 
 
    'Ẽ': 'E', 'Ề': 'E', 'Ế': 'E', 'Ệ': 'E', 'Ể': 'E', 'Ễ': 'E', 'Ị': 'I', 
 
    'Ỉ': 'I', 'Ĩ': 'I', 'Ọ': 'O', 'Ỏ': 'O', 'Ồ': 'O', 'Ố': 'O', 'Ộ': 'O', 
 
    'Ổ': 'O', 'Ỗ': 'O', 'Ơ': 'O', 'Ờ': 'O', 'Ớ': 'O', 'Ợ': 'O', 'Ở': 'O', 
 
    'Ỡ': 'O', 'Ụ': 'U', 'Ủ': 'U', 'Ũ': 'U', 'Ư': 'U', 'Ừ': 'U', 'Ứ': 'U', 
 
    'Ự': 'U', 'Ử': 'U', 'Ữ': 'U', 'Ỳ': 'Y', 'Ỵ': 'Y', 'Ỷ': 'Y', 'Ỹ': 'Y', 
 
    'Đ': 'D', 'ạ': 'a', 'ả': 'a', 'ầ': 'a', 'ấ': 'a', 'ậ': 'a', 'ẩ': 'a', 
 
    'ẫ': 'a', 'ằ': 'a', 'ắ': 'a', 'ặ': 'a', 'ẳ': 'a', 'ẵ': 'a', 'ẹ': 'e', 
 
    'ẻ': 'e', 'ẽ': 'e', 'ề': 'e', 'ế': 'e', 'ệ': 'e', 'ể': 'e', 'ễ': 'e', 
 
    'ị': 'i', 'ỉ': 'i', 'ĩ': 'i', 'ọ': 'o', 'ỏ': 'o', 'ồ': 'o', 'ố': 'o', 
 
    'ộ': 'o', 'ổ': 'o', 'ỗ': 'o', 'ơ': 'o', 'ờ': 'o', 'ớ': 'o', 'ợ': 'o', 
 
    'ở': 'o', 'ỡ': 'o', 'ụ': 'u', 'ủ': 'u', 'ũ': 'u', 'ư': 'u', 'ừ': 'u', 
 
    'ứ': 'u', 'ự': 'u', 'ử': 'u', 'ữ': 'u', 'ỳ': 'y', 'ỵ': 'y', 'ỷ': 'y', 
 
    'ỹ': 'y', 'đ': 'd', 
 
    // currency 
 
    '€': 'euro', '₢': 'cruzeiro', '₣': 'french franc', '£': 'pound', 
 
    '₤': 'lira', '₥': 'mill', '₦': 'naira', '₧': 'peseta', '₨': 'rupee', 
 
    '₩': 'won', '₪': 'new shequel', '₫': 'dong', '₭': 'kip', '₮': 'tugrik', 
 
    '₯': 'drachma', '₰': 'penny', '₱': 'peso', '₲': 'guarani', '₳': 'austral', 
 
    '₴': 'hryvnia', '₵': 'cedi', '¢': 'cent', '¥': 'yen', '元': 'yuan', 
 
    '円': 'yen', '﷼': 'rial', '₠': 'ecu', '¤': 'currency', '฿': 'baht', 
 
    "$": 'dollar', '₹': 'indian rupee', 
 
    // symbols 
 
    '©':'(c)', 'œ': 'oe', 'Œ': 'OE', '∑': 'sum', '®': '(r)', '†': '+', 
 
    '“': '"', '”': '"', '‘': "'", '’': "'", '∂': 'd', 'ƒ': 'f', '™': 'tm', 
 
    '℠': 'sm', '…': '...', '˚': 'o', 'º': 'o', 'ª': 'a', '•': '*', 
 
    '∆': 'delta', '∞': 'infinity', '♥': 'love', '&': 'and', '|': 'or', 
 
    '<': 'less', '>': 'greater', 
 
}; 
 

 
slug.defaults.modes = { 
 
    rfc3986: { 
 
     replacement: '-', 
 
     symbols: true, 
 
     remove: null, 
 
     lower: true, 
 
     charmap: slug.defaults.charmap, 
 
     multicharmap: slug.defaults.multicharmap, 
 
    }, 
 
    pretty: { 
 
     replacement: '-', 
 
     symbols: true, 
 
     remove: /[.]/g, 
 
     lower: false, 
 
     charmap: slug.defaults.charmap, 
 
     multicharmap: slug.defaults.multicharmap, 
 
    }, 
 
}; 
 

 
// Be compatible with different module systems 
 

 
if (typeof define !== 'undefined' && define.amd) { // AMD 
 
    // dont load symbols table in the browser 
 
    for (var key in slug.defaults.modes) { 
 
     if (!slug.defaults.modes.hasOwnProperty(key)) 
 
      continue; 
 

 
     slug.defaults.modes[key].symbols = false; 
 
    } 
 
    define([], function() {return slug}); 
 
} else if (typeof module !== 'undefined' && module.exports) { // CommonJS 
 
    symbols(); // preload symbols table 
 
    module.exports = slug; 
 
} else { // Script tag 
 
    // dont load symbols table in the browser 
 
    for (var key in slug.defaults.modes) { 
 
     if (!slug.defaults.modes.hasOwnProperty(key)) 
 
      continue; 
 

 
     slug.defaults.modes[key].symbols = false; 
 
    } 
 
    root.slug = slug; 
 
} 
 

 
}(this)); 
 

 
var content = { 
 
\t 'topicVideo': { 
 
    \t 'id': '197505065', 
 
    'categorySort': 18, 
 
    'categoryName': 'Hayatımızda Kimya', 
 
    'contentSort': 2, 
 
    'contentName': 'Yüzey Aktif Maddeler', 
 
    'fileName': 'KonuAnlatimi.mp4' 
 
    } 
 
} 
 

 
function getContent(content, categoryId) { 
 
    console.log(content.topicVideo); 
 
    return { 
 
     // _id: Random.id(), 
 
     // other properties 
 
     contentSlug: slug(content.topicVideo.contentName, undefined) 
 
    }; 
 
} 
 

 
console.log(getContent(content, 1));

2

要确保的ToString()不会抛出一个错误,你可以:的

string = "" + string; // amends the value to an string, even if its undefined or null etc 

代替:

string = string.toString(); 

但是你还可以检查字符串的值是否未定义或为空。 另请参阅here

+0

这是一个广泛使用的npm模块。我不想更改代码 – osrl

+0

嗯,它在你身上,但至少我会推荐检查null或undefined,如果它会抛出错误。 – fuma

相关问题