关于typo中tag中的keywords_to_tags

在用typo发布文章的时候我在标签栏如果我只填写一个词 jjj 的话 如果两个就不会有问题, 就会报

Tag expected, got NilClass错误,下面是tag中关于分词到tags表的一个方法

 def keywords_to_tags
    Article.transaction do
      tags.clear
      keywords.to_s.scan(/((['"]).*?\2|[\.\w]+)/).collect do |x|
        x.first.tr("\"'", '')
      end.uniq.each do |tagword|
        tags << Tag.get(tagword)
      end
    end
  end

开始我以为是each的时候多打印一次,结果好像没有这个问题

  def self.get(name)
    tagname = name.tr(' ', '').downcase
    tag = find_by_name_or_display_name(tagname, name)
    if tag.nil?
      tag = Tag.create(:name => tagname, :display_name => name)
    end
  end

  def self.find_by_name_or_display_name(tagname, name)
    self.find(:first, :conditions => [%{name = ? OR display_name = ? OR display_name = ?}, tagname, tagname, name])
  end

不过我不明白他这个tags是 tags << Tag.get(tagword) 为空的时候是怎么处理的不用去判断是否为空吗?

对于他的表设计也有些不明白,为什么有name 还要加个display name呢,如果改成user_id会更好一些,那么update_at才会有意义,现在的话update_at也变得没有意思了,再加个标签被引用的数量就更好了

 

你可能感兴趣的:(rails ruby typo)