Solved

how can I force the browser to appreciate a change to the background image on an asp page.

Posted on 2011-09-29
10
227 Views
Last Modified: 2012-06-27
this is driving me mad!

my background image is defined in css and I have an asp page that allows the user to change the contents of that image file (background.jpg) defined in the css.

my problem is that whenever the background.jpg image file is replaced using vb code I still have to tell the user to hit F5 for the change to show in the browser. All browsers seem to remember the previous image and always use that one instead of the incumbent one.

So what do I have to do to ensure that the new background image is immediately applied when returning to the homepage after selecting a new image.
0
Comment
Question by:JOHNFROG
  • 4
  • 3
  • 2
  • +1
10 Comments
 
LVL 1

Expert Comment

by:Doddsy1000
ID: 36815290
Can you run F5 as a macro? Maybe execute it from the return to the homepage?

If you can, maybe shift & f5 to overcome the cache.

Either that, or you might find what you are after in the security/miscellaneous section of "internet properties" in control panel.

good luck with that.

cheers

Ian
0
 
LVL 30

Expert Comment

by:LZ1
ID: 36815341
You have a couple of different ways to do it.
1) You could add the meta no cache to the head of your site
<META HTTP-EQUIV="CACHE-CONTROL" CONTENT="NO-CACHE">

2) You could time stamp your CSS file:



<link rel="stylesheet" type="text/css" href="style.css?<%response.write(time())%>">

Open in new window

0
 

Author Comment

by:JOHNFROG
ID: 36815584
LZ1 - Have tried that but still dont get the desired effect unless I hit F5.

No matter which browser I use the change is not observed unless I hit F5.

When I look at other websites that let you change the theme it works so why not my website? driving me crazy!

0
Announcing the Most Valuable Experts of 2016

MVEs are more concerned with the satisfaction of those they help than with the considerable points they can earn. They are the types of people you feel privileged to call colleagues. Join us in honoring this amazing group of Experts.

 
LVL 30

Expert Comment

by:LZ1
ID: 36815600
Even the time stamp doesn't work?
0
 

Author Comment

by:JOHNFROG
ID: 36815673
no. time stamp doesnt work. wish it did though. must be something on the server maybe.
0
 
LVL 30

Expert Comment

by:LZ1
ID: 36815746
I was just going to suggest that. It could be something with IIS.  However, what happens if you try to add anything else dynamically like
styles.css?token=1234

I know the timestamp didn't work, but does that work?
0
 

Author Comment

by:JOHNFROG
ID: 36815925
To be Honest - I dont really know how to test that. (token=1234). If I add it to the css line how do I know if it is being added?

Is there a way to point to a different file in css rather that changing the contents of the file being pointed to.

0
 
LVL 7

Accepted Solution

by:
NauticalNonsense earned 500 total points
ID: 36817570
Can you change your code to use HTML for the background image (instead of the CSS)?

<body runat="server" id="body">

and then add a

body.Attributes.Add("style", "background-image: url(images/pattern.png?" + System.DateTime.Now.ToString());

type of thing?

I've had to use additional info after images to get them to load every time, so maybe this will work for ya.
0
 

Author Closing Comment

by:JOHNFROG
ID: 36819011
you know I really thought that would have worked. but still - the F5 must be used.

It occurs to me that I cannot change the contents of an image file and expect the server to realize it has changed. So I must revert to pointing the background to a new file each time.

So I used the
 body.Attributes.Add("style", "background-image: url( ....
example and am storing the required image url in the database.

hallelujah ... it works a treat. And using the database solution I can control tiling etc better and even keep track of different backgrounds for each individual page.

Worked out alot better than I intended.

Thanks to all those who have helped but points must go to nautical nonsense.
0
 
LVL 7

Expert Comment

by:NauticalNonsense
ID: 36819036
ssssssssshhpow!

happy it worked for you :)
0

Featured Post

Announcing the Most Valuable Experts of 2016

MVEs are more concerned with the satisfaction of those they help than with the considerable points they can earn. They are the types of people you feel privileged to call colleagues. Join us in honoring this amazing group of Experts.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

Title # Comments Views Activity
Problem to refer to value 8 51
Border and image sizing 5 20
RLDC Reporting in Visual studio 11 17
What are the simplest ways to create a Merge Sort? 3 16
This is a how to build your own CSS3 slideshow and when I say CSS3 I mean just CSS with no javascript in sight! There a few examples online of how to do this but most just show you an example without any explanation, others make it more complicat…
International Data Corporation (IDC) prognosticates that before the current the year gets over disbursing on IT framework products to be sent in cloud environs will be $37.1B.
In this tutorial viewers will learn how to style rounded corners for elements in CSS using the border-radius property Begin with a normal styled element such as a div: To style all four corners of the div to be the same degree of roundness, use the …
The viewer will learn the benefit of using external CSS files and the relationship between class and ID selectors. Create your external css file by saving it as style.css then set up your style tags: (CODE) Reference the nav tag and set your prop…

825 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question