Jaka jest różnica między ngModel. $ ModelValue i ngModel. $ ViewValue

Mam następującą dyrektywę ckEditor. Na dole znajdują się dwie odmiany, które widziałem z przykładów dotyczących ustawiania danych w edytorze:

app.directive('ckEditor', [function () {
    return {
        require: '?ngModel',
        link: function ($scope, elm, attr, ngModel) {

            var ck = null;
            var config = attr.editorSize;
            if (config == 'wide') {
                ck = CKEDITOR.replace(elm[0], { customConfig: 'config-wide.js' });
            } else {
                ck = CKEDITOR.replace(elm[0], { customConfig: 'config-narrow.js' });
            }


            function updateModel() {
                $scope.$apply(function () {
                    ngModel.$setViewValue(ck.getData());
                });
            }

            $scope.$on('modalObjectSet', function (e, modalData) {
                // force a call to render
                ngModel.$render();
            });

            ck.on('change', updateModel);
            ck.on('mode', updateModel);
            ck.on('key', updateModel);
            ck.on('dataReady', updateModel);

            ck.on('instanceReady', function () {
                ngModel.$render();
            });

            ck.on('insertElement', function () {
                setTimeout(function () {
                    $scope.$apply(function () {
                        ngModel.$setViewValue(ck.getData());
                    });
                }, 1000);
            });

            ngModel.$render = function (value) {
                ck.setData(ngModel.$modelValue);
            };

            ngModel.$render = function (value) {
                ck.setData(ngModel.$viewValue);
            };
        }
    };
}])

Czy ktoś może mi powiedzieć, jaka jest różnica między:

ck.setData(ngModel.$modelValue);
ck.setData(ngModel.$viewValue);

I którego powinienem użyć. Spojrzałem na dokumentację kanciastą i mówi:

$viewValue

Actual string value in the view.

$modelValue

The value in the model, that the control is bound to.

Nie mam pojęcia, co autor miał na myśli, pisząc to w dokumencie :-(

questionAnswers(3)

yourAnswerToTheQuestion