如果数据是新的则添加或当数据是不同的angularjs时更新

时间:2015-10-22 16:08:33

标签: javascript angularjs

我正在尝试更新数据,而不是在图像更改时添加(创建)新数据(图像在base64中)

我也跟着:http://jsfiddle.net/4Zeuk/12/就像我在下面尝试做的那样,但我已经尽力了但是更新无效。没有错误。

仅供参考,我使用的是ngCropper。 https://github.com/koorgoo/ngCropper

编辑:更新控制器代码

角度代码

      app.controller("ProductAddCtrl", function($scope, $timeout, $resource, Product, Products, $location, Cropper) {
        $scope.product = {item_name: '', price: '', category: ''}
        var file, data;

        $scope.saveImage = function(dataUrl) {
          if (!file || !data) return;
           if ($scope.product.currentImage){
              Cropper.crop(file, data).then(Cropper.encode).then(function(dataUrl) {
                ($scope.preview || ($scope.preview = {})).dataUrl = dataUrl;
                  Product.update({id: $scope.product.id }, {product: { item_name: $scope.product.item_name, category: $scope.product.category, price: $scope.product.price, item_image: dataUrl, filename: file.name}},function(){
            //  $location.path('/');
                console.log($scope.product)
                }, function(error) {
                  console.log(error)
                });
              });
            } else {
              Cropper.crop(file, data).then(Cropper.encode).then(function(dataUrl) {
                ($scope.preview || ($scope.preview = {})).dataUrl = dataUrl;
                  Products.create({ product: { item_name: $scope.product.item_name, price: $scope.product.price, item_image: dataUrl, filename: file.name }}, function(){
                  // $location.path('/');
                  }, function(error){
                    console.log(error)
                  });
              })
            }
          }

          $scope.onChange = function() {
            if ($scope.product.currentImage) {
              $scope.product.item_image = $scope.product.currentImage.item_image;
              $scope.product.filename = $scope.product.currentImage.filename;
            } else {
              $scope.product = {};
            }
          }
  });

角度模板文件

<div class="content-push">
  <input type="file" onchange="angular.element(this).scope().onFile(this.files[0])" ng-class="{'has-error' : productForm.item_image.$invalid}" ng-model="product.currentImage" ng-change="onChange" required>
    <br />
    <div ng-if="dataUrl" class="img-container">
      <img ng-if="dataUrl" ng-src="{{dataUrl}}" width="300" height="300"
          ng-cropper
          ng-cropper-proxy="cropperProxy"
          ng-cropper-show="showEvent"
          ng-cropper-hide="hideEvent"
          ng-cropper-options="options">
    </div>
    <br />
      <button ng-click="preview()" class="btn btn-success">Show preview</button>
      <button ng-click="zoomin()" class="btn btn-default">Zoom In</button>
      <button ng-click="zoomout()" class="btn btn-default">Zoom Out</button>
      <!-- <button ng-click="saveImage()" class="btn btn-default">Save</button> -->
      <input type="submit" value="{{ product.currentImage.item_image ? 'Update' : 'Save' }}", class="btn btn-default" ng-click="saveImage()">
      <div class="preview-container">
        <img ng-if="preview.dataUrl" ng-src="{{preview.dataUrl}}" width="100" height: "100">
      </div>
      <select name="sellCategory" class="form-control" id="sellCategory" ng-model="product.category" required>
        <option ng-repeat="option in categories.availableCategories" value="{{option.category}}">{{option.name}}</option>
      </select>
      <input type="text" ng-model="product.item_name" class="form-control" placeholder="Item Name" required>
      <input type="text" ng-model="product.price" class="form-control" placeholder="Item Price" required>
</div>

1 个答案:

答案 0 :(得分:0)

我把这个概念弄错了。

假设我有多个文件上传功能,而不是逐个配置angularjs上传文件(通过PUT请求),我会选择base64格式的每个文件(用于预览),然后输入字段(如价格,客户端的项目类别和名称)在angularjs中,而不是POST PUTting每个数据。

因此,在客户端的所有内容都设置了图像预览(我打算有四个)和数据后,我会将其保存(POST)到后端。

感谢所有看过我问题的人。