utilitaire Posted July 21, 2005 Posted July 21, 2005 (edited) <img src="<%=image_path%>" runat=server> ????? This is a very simple question: how do I put a string value into a tag runat=server like this: <img src="<%=image_path%>" runat=server> This simply doesnt work with the runat=server proprety. IIS does not replace the variable «image_path». I need to do use this variable because my images path is dynamic. Please dont suggest me to set the «src» property of the image control in the code-behind class. This is way too messy since I have more than 300 images in my template ascx. I can't just do: myImg1.Src = image_path; myImg2.Src = image_path; myImg3.Src = image_path; myImg4.Src = image_path; myImg5.Src = image_path; myImg6.Src = image_path; myImg7.Src = image_path; ... and so on Any Idea? Edited July 21, 2005 by utilitaire Quote
evaleah Posted July 21, 2005 Posted July 21, 2005 If I am understanding you correctly then you have a user control that you want a different image to appear based on what page calls the control. You want to set this value in the calling page and let the user control read it. Try adding a hidden html control and make it public. Set the value to be the value you want for image_path. For example: <input id="ImagePath" type="hidden" value="image_path" name="ImagePath" runat="server"><br> Your code behind declaration of the hidden control should read: Public WithEvents ImagePath As System.Web.UI.HtmlControls.HtmlInputHidden When you incorporate the usercontrol into a page set the value of the control to be the image path you want. For example: MyUserControl.ImagePath.Value = "theactualimagepath" Then again, back at your usercontrol. In your page load set the src of your image control from the hidden control. myImg1.src = ImagePath.Value I know that is a bit of a complicated explanation but I did my best to make it clear! HTH Eva Quote
utilitaire Posted July 21, 2005 Author Posted July 21, 2005 If I am understanding you correctly then you have a user control that you want a different image to appear based on what page calls the control. You want to set this value in the calling page and let the user control read it. Try adding a hidden html control and make it public. Set the value to be the value you want for image_path. For example: <input id="ImagePath" type="hidden" value="image_path" name="ImagePath" runat="server"><br> Your code behind declaration of the hidden control should read: Public WithEvents ImagePath As System.Web.UI.HtmlControls.HtmlInputHidden When you incorporate the usercontrol into a page set the value of the control to be the image path you want. For example: MyUserControl.ImagePath.Value = "theactualimagepath" Then again, back at your usercontrol. In your page load set the src of your image control from the hidden control. myImg1.src = ImagePath.Value I know that is a bit of a complicated explanation but I did my best to make it clear! HTH Eva Thank you for you answer. But this line is what I want to avoid: "myImg1.src = ImagePath.Value" Like I said, I have hundreds of image Control in my pages. I absolutely cannot initialyse all these controls in the code-behind, because it would be a mess (and a total horror) for the programmers. I'd be forced to declare all thoses control and initialyse them in the code behind. Awfull. I just want to add controls in the html code without having to deal with them in the code-behind. Thank you again. If you have another solution please help me! Quote
evaleah Posted July 21, 2005 Posted July 21, 2005 I guess I am confused about what you are really trying to do. You have to set the value of the variable somewhere. Where are you setting the value of the variable? Aren't you doing that in code? If you aren't doing it in code somewhere it's not dynamic. In that case just put in your image path string. Quote
utilitaire Posted July 22, 2005 Author Posted July 22, 2005 I guess I am confused about what you are really trying to do. You have to set the value of the variable somewhere. Where are you setting the value of the variable? Aren't you doing that in code? If you aren't doing it in code somewhere it's not dynamic. In that case just put in your image path string. Here's what I do in the code behind: if(myculture == ENGLISH) image_path = "http://mysite.com/images/en/"; else image_path = "http://mysite.com/images/fr/"; Here's what I do in my aspx page: <img src="<%=image_path%>" id=img1 runat=server> <img src="<%=image_path%>" id=img2 runat=server> <img src="<%=image_path%>" id=img3 runat=server> <img src="<%=image_path%>" id=img4 runat=server> As you can see, I set a value to "image_path". This value depens actually on the cultureinfo. All the images are both in english and in french. There's a separated directory for both languages. This is why I said the path was «dynamic». I dont know if you ever faced this kind of problem with runat=server controls. When I work with html tag, not control, it works fine. But if I put the «runat=server» into the tag, the string wont be replaced be the value that I setup in the code-behind. :confused: :confused: :confused: Quote
utilitaire Posted July 22, 2005 Author Posted July 22, 2005 As I said, I want my code-behind to be very clean(I dont know if its the correct word). I accept to do this part in the code-behind, as it is very short and I can encapsulate this so the programmers wont have to deal with it in the future: if(myculture == ENGLISH) image_path = "http://mysite.com/images/en/"; else image_path = "http://mysite.com/images/fr/"; But here's what I dont want to do: if(myculture == ENGLISH) image_path = "http://mysite.com/images/en/"; else image_path = "http://mysite.com/images/fr/"; img1.src = image_path + "img1.gif"; img2.src = image_path + "img2.gif"; img3.src = image_path + "img3.gif"; img4.src = image_path + "img4.gif"; img5.src = image_path + "img5.gif"; img6.src = image_path + "img6.gif"; img7.src = image_path + "img7.gif"; img8.src = image_path + "img8.gif"; img9.src = image_path + "img9.gif"; You agree that is way too long. I absolutely cant do that. Quote
Hyuga Posted July 22, 2005 Posted July 22, 2005 And why don't you do a loop to assign all the values? you can loop from 1 to NUMBER_OF_IMAGES and try to find the control imgX in every round. When you have the control: imgX.src = image_path + "img" + i.ToString + ".gif"; Have you tried? Quote
Jackpanel Posted July 22, 2005 Posted July 22, 2005 <%="<img src='" & image_path & "img1.gif'>" %> Quote
evaleah Posted July 22, 2005 Posted July 22, 2005 <%="<img src='" & image_path & "img1.gif'>" %> Right, I know that part. What I don't know is FROM where you want to SET that value of "image_path". Just putting a variable someplace doesn't assign it a value. How did you *want* to assign the value? Where were you thinking of doing that? Maybe if you tell me that there might be other options. It's just that you have to assign a value somewhere in order to read it here. Does what I am asking you make more sense now? Quote
utilitaire Posted July 22, 2005 Author Posted July 22, 2005 Right, I know that part. What I don't know is FROM where you want to SET that value of "image_path". Just putting a variable someplace doesn't assign it a value. How did you *want* to assign the value? Where were you thinking of doing that? Maybe if you tell me that there might be other options. It's just that you have to assign a value somewhere in order to read it here. Does what I am asking you make more sense now? Here's what I do: public class MyPage: Page{ protected string image_path; public void page_load(...){ image_path = "http://mysite.com/fr/"; } } As you can see, the image_path string can be access throught the webform that inherits from «MyPage». Quote
utilitaire Posted July 22, 2005 Author Posted July 22, 2005 <%="<img src='" & image_path & "img1.gif'>" %> Right, but what do I do if I want to make this image tag a Control? <%="<img src='" & image_path & "img1.gif' runat=server>" %> This wont work indeed. It will result in a string sent to the browser, but it will never be executed as a control. Quote
utilitaire Posted July 22, 2005 Author Posted July 22, 2005 And why don't you do a loop to assign all the values? you can loop from 1 to NUMBER_OF_IMAGES and try to find the control imgX in every round. When you have the control: imgX.src = image_path + "img" + i.ToString + ".gif"; Have you tried? Yeah it would work, in theory. But it would still become a mess: 1) I have hundred of images in my site. There is no way the designers will name all the images «imgX.gif». Too messy. If all images have a different name, how can I loop? 2) With hundred of images, it would slow down the web site. I'd have to search recursivly from the root control throught all the controls in the page in order to find all the images. 3) The same problem will appear with background properties in table, td, tr, body. The same problem will appear in «input type=submit» button, «input type=button» button, etc. I think you'll agree that its way too complicated and way too heavy. Quote
evaleah Posted July 22, 2005 Posted July 22, 2005 But here's what I dont want to do: if(myculture == ENGLISH) image_path = "http://mysite.com/images/en/"; else image_path = "http://mysite.com/images/fr/"; img1.src = image_path + "img1.gif"; img2.src = image_path + "img2.gif"; img3.src = image_path + "img3.gif"; img4.src = image_path + "img4.gif"; img5.src = image_path + "img5.gif"; img6.src = image_path + "img6.gif"; img7.src = image_path + "img7.gif"; img8.src = image_path + "img8.gif"; img9.src = image_path + "img9.gif"; You agree that is way too long. I absolutely cant do that. I have to admit, I don't understand why you don't want to do that. You won't take a performance hit to do it in the code rather than in the html. It's still faster to do it this way than to create the controls at runtime. Since you need the path to be dynamic and all the images are different, I'm afraid this is the most effecient way. Especially if all the image names are not something you can loop. Otherwise, the loop option is the best you've got. If you name all your img html objects the same as the images you are looking for you could run your loop that way. It just seems to me you are avoiding one method without really gaining anything. Whether you set the variable "image_path" or the src itself in code, either way you have to set something in code. The easiest and fastest way to get the image you want is to set it as we have all suggested here. Quote
utilitaire Posted July 22, 2005 Author Posted July 22, 2005 I'm not so sure... 1) My web site has more than 2000 images, with specific names like «button_leave.gif». You're telling me to rename all those images in the «imgX.gif» form??? :o 2) Are you so sure that I dont take a performance hit while doing a recursive loop? Everytime a page is called(this has to be done in every Request), IIS would have to loop recursively throught ALL the controls in my page. For each control, loop throught all controls, in witch you loop recursively throught all controls, in witch you loop recursively in all controls... I dont know you, but to me it seems a bit heavy. My web site has more than 4 million request per day. I absolutely cannot sacrifice performance here. Are you sure it is faster than simply doing a response.write in the webform? 3) If it was only for images, it would be easier to program. But this philosophy would have to be apply to all sort of control that take a «src» attribute. If I want to use a «asp:button» control, I will have to do the same thing(recursive loop) in the code behind. Very depressive dont you think??? :confused: 4) Since I like to keep the code-behind very clean, it would be very sad to put 200 control declaration in the class definition. Imagine how horrible it would look like. Asp.net is supposed to be faster than classic asp. I dont want the programmers to comit suicide everytime they have to put some image control in their webform! ;) Quote
utilitaire Posted July 23, 2005 Author Posted July 23, 2005 I cant believe I'm the only one in the world who faced this problem when using controls with dynamic image path. How do you deal with it??? If you have a magic solution, please tell me! How do you manage to inform the browser that all images are either in the "fr" directory, or in the "en" directory, or in the "sp" directory, depending on the cultureinfo the client is using. http://www.mysite.com/fr/demo.gif http://www.mysite.com/en/demo.gif http://www.mysite.com/sp/demo.gif ... How would you do it? I'm looking for a solution that is: 1) performant (large amount of visitors) 2) clean (I mean that I dont want to write 3 hundred lines of code just to initialyse the images src.) thank you for your help! Quote
Jackpanel Posted July 25, 2005 Posted July 25, 2005 Probably your best solution would be to loop through all image controls and adjust the ImageURL property to the right folder. Here's an example, where I'm setting the folder to pick from using the sLanguage variable. I go through all controls in the page, and if its an image, replace the "~" in the image path with a "~/FR". This requires your images all have the url set to "~/imagename.gif" style, but you can adjust it if you have a different setup: Private Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load Dim sLanguage As String = "FR" SetImagePath(Page, sLanguage) End Sub Private Sub SetImagePath(ByVal p_Control As Control, ByVal p_Language As String) Dim ctrl As Control For Each ctrl In p_Control.Controls If TypeOf ctrl Is System.Web.UI.WebControls.Image Then Dim sNewPath As String sNewPath = CType(ctrl, System.Web.UI.WebControls.Image).ImageUrl.Replace("~", "~/" & p_Language) CType(ctrl, System.Web.UI.WebControls.Image).ImageUrl = sNewPath Else If ctrl.Controls.Count > 0 Then SetImagePath(ctrl, p_Language) End If End If Next End Sub Quote
utilitaire Posted July 25, 2005 Author Posted July 25, 2005 It's called CSS! Use it! ???? give you 50 bucks if you make it work that way ;) Quote
utilitaire Posted July 25, 2005 Author Posted July 25, 2005 Probably your best solution would be to loop through all image controls and adjust the ImageURL property to the right folder. Here's an example, where I'm setting the folder to pick from using the sLanguage variable. I go through all controls in the page, and if its an image, replace the "~" in the image path with a "~/FR". This requires your images all have the url set to "~/imagename.gif" style, but you can adjust it if you have a different setup: Private Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load Dim sLanguage As String = "FR" SetImagePath(Page, sLanguage) End Sub Private Sub SetImagePath(ByVal p_Control As Control, ByVal p_Language As String) Dim ctrl As Control For Each ctrl In p_Control.Controls If TypeOf ctrl Is System.Web.UI.WebControls.Image Then Dim sNewPath As String sNewPath = CType(ctrl, System.Web.UI.WebControls.Image).ImageUrl.Replace("~", "~/" & p_Language) CType(ctrl, System.Web.UI.WebControls.Image).ImageUrl = sNewPath Else If ctrl.Controls.Count > 0 Then SetImagePath(ctrl, p_Language) End If End If Next End Sub I thought about it and its not so bad. The major problems are: 1) You have to do a recursive loop throught all controls in all sub-usercontrols. Isn't it heavy??? 2) I would need to do this not only for System.Web.UI.WebControls.Image. But also for: -ImageButton -Input type="image" -Image -Body -Table backgroud="http://..." Its a lot of exceptions dont you think? Every time I discover another control who need a source image, I'd have to update my pages? 3) What if I want some images not to refer to my image_path? Suppose most of images refer to "image_path", but 10 images in the whole site refer to another domain name(http://www.google.com/images/toto.gif" for instance). The loop would convert the google link into: image_path + "http://www.google.ca/images/toto.gif" witch is wrong. :confused: Quote
Jackpanel Posted July 25, 2005 Posted July 25, 2005 1) yeah, it would be a heavy way of handling it. Depends on your application whether or not this is reasonable. 2) You should be able to figure out in advance all the possible controls and expand the If-Else to handle each. You can share this sub with all pages in your app, so you'd only have to do it once. 3) The replace function is looking for ~, so shouldn't affect any external links. Another option would be to set the page base in the header: <%@ Page Language="vb" AutoEventWireup="false" Codebehind="test.aspx.vb" Inherits="test"%> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"> <HTML> <HEAD> <title>test</title> <asp:literal id="litSetBase" runat="server"></asp:literal> </HEAD> <body> <form id="Form1" method="post" runat="server"> <img src="choose.gif"> </form> </body> </HTML> Private Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load litSetBase.Text = "<BASE href='http://localhost/FR/'>" End Sub However, this will also affect any relative links you may have used in your pages. Quote
utilitaire Posted July 26, 2005 Author Posted July 26, 2005 3) The replace function is looking for ~, so shouldn't affect any external links. Another option would be to set the page base in the header: Thank you very much! So amazing! I didn't even know it was possible to setup the root path in HTML for all relative links!!! For every image src, I'll just put «myImages/img1.gif» You saved me thousans lines of useless code!!! I think I'll solve most of the problems! The only disadvantage I see is that I wont be able no more to put relative links to navigate between pages that are in the same directory. I'll have to put the whole path from the new base directory, witch will be: "http://mysite.com/fr/" or "http://mysite.com/en/". So if I'm in the /fr/sub1/sub2/sub3/page1.aspx, and I want to put a link to /fr/sub1/sub2/sub3/page2.aspx, I'll have to write the whole path (sub1/sub2/sub3/page2.aspx). Quote
Recommended Posts
Join the conversation
You can post now and register later. If you have an account, sign in now to post with your account.