Посмотрите на этот пример:
var app = angular.module('plunker', []);
app.controller('MainCtrl', function($scope,$http) {
var getJoke = function(){
return $http.get('http://api.icndb.com/jokes/random').then(function(res){
return res.data.value;
});
}
getJoke().then(function(res) {
console.log(res.joke);
});
});
Как вы можете видеть, getJoke
возвращает разрешенное обещание (оно разрешено при возврате res.data.value
). Таким образом, вы ждете, пока запрос $ http.get не будет завершен, а затем выполнится console.log (res.joke) (как обычный асинхронный поток).
Это plnkr:
Это скорее обходной путь, но его можно использовать
iris %>% mutate(sumVar = rowSums(.[1:4]))
Как написано в комментариях, вы также можете использовать select
внутри мутанта, чтобы получить столбцы, которые вы хотите суммировать например,
iris %>%
mutate(sumVar = rowSums(select(., contains("Sepal")))) %>%
head
или
iris %>%
mutate(sumVar = select(., contains("Sepal")) %>% rowSums()) %>%
head
Более сложным способом будет:
iris %>% select(Sepal.Length:Petal.Width) %>%
mutate(sumVar = rowSums(.)) %>% left_join(iris)
Я использую это простое решение, которое является более надежной модификацией ответа Давида Пассаретти:
iris %>% select(Sepal.Length:Petal.Width) %>%
transmute(sumVar = rowSums(.)) %>% bind_cols(iris, .)
(Но для этого требуется определенный порядок строк, что должно быть хорошо, если вы не работаете возможно, с удаленными наборами данных.)
Добавление комментария @ docendodiscimus в качестве ответа. +1 к нему!
iris %>% mutate(sumVar = rowSums(select(., contains("Sepal"))))