javascript - 如何在 Meteor 启动时将图像上传到服务器

标签 javascript meteor spacebars meteor-helper collectionfs

我正在尝试为没有/未上传图像的用户设置默认 DP。

尝试使用帮助程序显示内容,但收到错误“未捕获错误:{{#each}} 当前仅接受数组、游标或错误值。” 下面的代码(客户端JS) JS:

Template.mcomments.helpers({
    'mcommentsdata':function(){
      return comdata.find({},{sort:{"at":-1}}).fetch();
    },

    images2: function () {
        var fetchimg=Meteor.users.findOne({
            "_id":this.__id
          });

        if((fetchimg.profileimage==undefined)||(fetchimg.profileimage=="")){
        var hello="/images/prof.jpg"
        return hello;
        }else{
            return Images.find({"_id":fetchimg.profileimage})


        }
    }
  });

HTML

    <template name="mcomments">
<div id="mcomments" class="col-lg-3">
    <div><h5 class="mcommentsheader">Followup Stream </h5>
    </div>
    <div class="col-lg-12 scrolling comscrolllist" id="mcomments1">
        <div id="mcomments2">
            {{#each mcommentsdata}}
            <div class="col-lg-12 comcontainer">
                <div class="row">
                    <div class="col-lg-3 indcomments" >
                        {{#each images2}}
                        <img src="{{this.url
                        }}" width="45px" height="50px" alt="">
                        {{/each}}
                    </div>
                    <div class="col-lg-9" style="">
                        <div class="row combody" >
                            <div class="pull-left mcommfont" >{{user}}</div>
                            <div class="pull-right mcommcust">{{product}} Case#{{productcaseno}}</div>
                        </div>
                        <div class="maincomment">{{comment}}</div>
                        <div class="comtemp"> <span data-livestamp="{{at}}"></span></div>
                    </div>
                </div>
            </div>

            <div class="col-lg-12 comblankspace">
            </div>
            {{/each}}
        </div>
    </div>
</div>
</template>

现在我已经放弃了这种方法,并考虑上传图像并默认将网址附加到所有配置文件(onCreateuser),直到他们更改它。我相信要做到这一点,我可能必须在服务器启动时自动上传和图像。请引导我走向正确的方向,因为我还是 meteor 新手。

存储适配器:GridFS。

问候, 阿扎鲁丁

最佳答案

将“hello”变量更改为以下代码:

var hello = [
    { url: "/images/prof.jpg" }
];

您遇到了问题,因为 hello 当前是一个字符串 - #each 需要一个数组/游标/等。正如您的错误所暗示的那样。

或者,您可以在每个 block 上使用 {{#else}} 并完全摆脱返回“hello”情况:

{{#each images}}
    ...
{{else}}
    <!-- Default profile image code -->
{{/each}}

关于javascript - 如何在 Meteor 启动时将图像上传到服务器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35076421/

相关文章:

javascript - 按特定键值对对象数组排序 | Javascript

javascript - meteor 无法观察带有 skip 或 limit 的查询

javascript - 使用变量作为名称来访问另一个数组的嵌套元素

javascript - JQuery 函数不返回 JSON 列表 - Play Framework、JPA

javascript - 如何让 JavaScript 发出哔哔声?

javascript - 如何使用 javascript 和中键单击在新选项卡中打开网页

javascript - 在 Meteor.js 中设置自动表单中省略字段的值

javascript - 为什么在尝试使用 Meteor search-source 包时出现错误?

javascript - 误解 `each...in` 用 react 变量渲染

javascript - meteor :在空格键中获取模板名称