React Native - Dapatkan cache panggilan
P粉585541766
P粉585541766 2023-10-21 23:44:23
0
2
677

Saya sedang membina apl dalam React Native yang membuat panggilan ambil yang bergantung pada pelayan untuk mendapatkan maklumat terkini. Saya perasan bahawa ia seolah-olah menyimpan cache respons, dan jika saya menjalankan panggilan ambil sekali lagi, ia mengembalikan respons yang dicache dan bukannya maklumat baharu daripada pelayan.

Fungsi saya adalah seperti berikut:

goToAll() {
  AsyncStorage.getItem('FBId')
    .then((value) => {
      api.loadCurrentUser(value)
        .then((res) => {
          api.loadContent(res['RegisteredUser']['id'])
            .then((res2) => {
              console.log(res2);
              this.props.navigator.push({
                component: ContentList,
                title: 'All',
                passProps: {
              content: res2,
            user: res['RegisteredUser']['id']
          }
        })
      });
    });
  })
  .catch((error) => {console.log(error);})
  .done();
}

Fungsi api.js yang saya panggil adalah seperti berikut:

loadContent(userid){
  let url = `http://####.com/api/loadContent?User_id=${userid}`;
  return fetch(url).then((response) => response.json());
}


P粉585541766
P粉585541766

membalas semua(2)
P粉548512637

Jawapan Manosim tidak berkesan untuk saya, tetapi membawa saya ke jalan yang sangat berfungsi:

fetch(url, {
  headers: {
    'Cache-Control': 'no-cache, no-store, must-revalidate',
    'Pragma': 'no-cache',
    'Expires': 0
  }
})

Ini menyelesaikan masalah.

P粉738248522

Anda boleh menetapkan 标头 untuk mengelakkan permintaan daripada dicache. Contoh di bawah:

return fetch(url, {
  headers: {
    'Cache-Control': 'no-cache'
  }
}).then(function (res) {
  return res.json();
}).catch(function(error) {
  console.warn('Request Failed: ', error);
});
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan