HTML <a> download Attribute - json

I wanted to know how to disable the "download" attribute for an anchor tag like download="false" :
<a href="https://cdn1.iconfinder.com/data/icons/HTML5/512/HTML_Logo.png" download></a>
I have an application built using angularjs and the interaction I am expecting to build is, all image files can be viewed but any non-image file will be downloaded
I am unable to print the value of my json "downloadable" parameter using angular, I have a json which contains parameter that determines if a file is downloadable or not, if its downloadable then "downloadable":"download" and if the file is not downloadable which means it is an image file it may simply be viewed in the browser, in that case I set "downloadable":"" and my anchor code is
<a href="https://cdn1.iconfinder.com/data/icons/HTML5/512/HTML_Logo.png" {{downloadable}}></a>
this does not print "download" in place of "downloadable", but if I try the following code
<a href="https://cdn1.iconfinder.com/data/icons/HTML5/512/HTML_Logo.png" data={{downloadable}}>
it gets rendered as expected i.e

Probably more correct to use data-* attributes as intended. Try data-downloadable="true". But if you want the resource to be downloadable you have to host them yourself. See https://developer.mozilla.org/en-US/docs/Web/HTML/Element/a . You can't offer download of other people's resources.

Related

Embed HTML within a URL

Is it possible to embed HTML within a URL and then render that HTML in the browser itself?
In theory, what 'm thinking of works similarly to an URL like below:
http://"<h1>Hello World</h1>"
this would show a page with "Hello World" wrapped in a <h1> tag.
Of course, I understand that the above does not work in the real world for a wide range of reasons. Is there however a a way in which I can encode data within a URL and show render that data as HTML within the browser?
I understand that you could easily set up a webserver to do this, but I am interested in a solution which would work natively without any dependencies.
It's Data URL. Data URLs, URLs prefixed with the data: scheme, allow content creators to embed small files inline in documents. They were formerly known as "data URIs" until that name was retired by the WHATWG.
Data URLs are treated as unique opaque origins by modern browsers, rather than inheriting the origin of the settings object responsible for the navigation.
Syntax:
data:[<mediatype>][;base64],<data>
The HTML:
Test
This is what a data url does.
Go to welcome page

Custom name in 'data:...' link

Recently, I learned, I can take source like base64ed text. For example:
<img src="data:image/jpeg;base64, /9j/4AAQSk...">
But, if I try to download such image, I got download.jpeg (or some another voodoo, made by browser). And it's sure thing, because it is encoded data of image only, names are discarded. Can I add custom name to data:... link?
If you just give me link to documentation about data:... or just official name of this "link", by that I could find it, I'll be grateful.
this hacky way 'll work only for right click -> Save as image :
<a download="bus.gif" href="">
<img src="">
</a>
For add file name to data:... you can't, The "data" URL scheme does not allow for specification of a file name.

i have a simple question about file directory in html and how to show the results of a file search

i have a piece of code that let's the user see find a file how do i get it to display where it is save eg desktop/folder/file.
my current code is a basic file input that goes like
<input type="file"/>
i want my page to display where the file is saved also on a side not is there a way to display search file results. I look up programing work and my page will show everything that is programing work in its name.
i have not tried anything as i am unsure where to start.
I'm pretty sure you want to get the full file path of a file uploaded via an HTML input element, if not, let me know.
If so, such behavior is intentionally blocked by most browsers, except for firefox. See How to get full path of selected file on change of <input type=‘file’> using javascript, jquery-ajax?. If you want to raed the file, you can use the FileReader class. Alternatively, you can make an object URL to the file object, on the onchange event, simply
var url = URL.createObjectURL(event.target.files[0]);
to use for reading purposes.

How do I link to a file page?

I have turned on $wgFileExtensions for pdf and uploaded a pdf-file and now I'm trying to create a pipe link to the corresponding file page like this:
[[File:test.pdf|Test file]]
But link text is ignored so the the link text is just the same as the url:
File:test.pdf
But i try to link to a png-file like this:
[[File:test.png|Test file image]]
Then everything works fine and the link text is like expected:
Test file image
Do i need to add any changes in the config, to allow pipe links to added filetypes?
And how do i do that?
To link to a page in the File namespace, put a colon before, like this:
[[:File:test.pdf|Test file]]
Otherwise, MW will try to embed the file. This has nothing to do with the file type, and the only reason it “works” in the test.png example is probably that the file test.png does not exist on your wiki.
Another namespace that has a special behaviour is the Category namespace, where adding a link like [[Category:Birds in Africa]], will add the current page to the category, whereas a link to the category page would need to look like this: [[:Category:Birds in Africa]] (or, more likely [[:Category:Birds in Africa|Birds in Africa]]).

Linking to PNG file beginning with hash symbol

I have two image files in my directory. One is called abc1.png and the other is called #abc1.png.
When I do
<img src="abc1.png" alt="Figure">
in my HTML file, it works fine. But when I do
<img src="#abc1.png" alt="Figure">,
the image doesn't show up. Why is it?
In HTML the # sign is a reference to a named anchor in the document. You are telling the browser to look for that. Instead, use the URI-encoded version of #:
<img src="%23abc1.png" alt="Figure">
Depending on your setup, you may have to double-encode it.