{
let cloned_ws = self.ws.clone();
let onopen_callback = Closure::wrap(Box::new(move |_| {
console_log!("socket opened");
let ping = Ping{
ping: "ping",
};
let serde = &JsValue::from_serde(&ping).unwrap();
let str = serde.clone().dyn_into::<js_sys::ArrayBuffer>();
console_log!("message event, received arraybuffer: {:?}", str);
match cloned_ws.as_ref().unwrap().send_with_array_buffer(&str.unwrap()) {
Ok(_) => console_log!("message successfully sent"),
Err(err) => console_log!("error sending message: {:?}", err),
}
// send off binary message
match cloned_ws.as_ref().unwrap().send_with_u8_array(&vec![0, 1, 2, 3]) {
Ok(_) => console_log!("binary message successfully sent"),
Err(err) => console_log!("error sending message: {:?}", err),
}
}) as Box<dyn FnMut(JsValue)>);
self.ws.as_ref().unwrap().set_onopen(Some(onopen_callback.as_ref().unchecked_ref()));
onopen_callback.forget();
}
все собирается, но в браузере вывливает ошибку, что не может сделать unwrap на строке
match cloned_ws.as_ref().unwrap().send_with_array_buffer(&str.unwrap())
Ну так разберись, почему не может. Очевидно у тебя там ошибка, а ты молча все ошибки затыкаешь unwrap-ами. Вставь код, который проверит и в случае чего выведет в консоль информацию об ошибке (видимо сериализация не прошла успешно)
И судя по коду - это у тебя не строка, а какой-то ArrayBuffer. Было бы неплохо соответствующим образом называть переменные, а то будешь "глазами долбится" в этот str и не понимать, почему строка не работает как строка.
Обсуждают сегодня